Podczas próby utworzenia skrótu do innego skrótu, Windows XP przypisuje cel oryginalnego skrótu do nowego skrótu. Dzieje się tak nawet wtedy, gdy ręcznie wprowadzam ścieżkę docelową i pozostaję z kopią oryginalnego skrótu. Nie tego chcę.
W jaki sposób .lnk
plik może wskazywać .lnk
bezpośrednio na inny plik? Ta forma podwójnej pośredniczości byłaby bardzo przydatna do zarządzania skrótami do plików, które często się przenoszą.
windows
windows-xp
shortcuts
użytkownik541686
źródło
źródło
Odpowiedzi:
W pełni rozumiem użyteczność linkowania do linków i szukałem również łatwego rozwiązania. Najlepszy, jaki wymyśliłem, to po prostu użyć Hardlinks, które wskazują na plik shortcut.lnk. Testowałem dowiązania symboliczne (połączenia są tylko dla folderów, a nie plików, więc nie zostały przetestowane) i te NIE działają (są to zasadniczo uszkodzone pliki podczas tworzenia, które nie otwierają się).
Linki twarde mają wiele zalet i wad. Podstawową wadą jest to, że tworzenie kopii zapasowych jest prawie niemożliwe (potrzebujesz oprogramowania lub skryptu innej firmy, aby wykonać ich kopię zapasową na innym nurkowaniu lub nawet w innym miejscu na tym samym dysku). Podstawową zaletą jest to, że aktualizują się one automatycznie po zmodyfikowaniu oryginalnego pliku, więc zmiana 1 pliku skrótu (nowa ścieżka / ikona) zmienia również wszystkie powiązane linki twarde [nazwy linku twardego są jednak unikalne, więc zmiana nazwy pliku nie zmień nazwę hardlink i odwrotnie]. Kolejną cechą, która jest zarówno zaletą, jak i wadą twardych linków, jest to, że zmiana ikony / ścieżki dla twardego linku (zmiana danych twardego linku) TAKŻE zmienia ORYGINALNY. NIE obejmuje to „usuwania samego linku” (link można usunąć jak każdy inny plik; bez usuwania samego oryginalnego pliku). Jest to korzystne, ponieważ utrzymuje synchronizację wszystkich powiązanych łączy, ale jest niekorzystne w przypadkach, w których hardlink jest przechowywany w wrażliwej lokalizacji, a jego dane są złośliwie modyfikowane lub błąd użytkownika podczas modyfikacji danych jednego łącza. Ta zmiana zostanie przeniesiona na wszystkich partnerów połączonych na stałe, w tym na oryginał. Szczerze mówiąc, takie zachowanie jest ogólnie przydatne, z wyjątkiem przypadków, w których chciałbyś mieć „stabilne źródło odniesienia” (modyfikacja 1-kierunkowa) Ta zmiana zostanie przeniesiona na wszystkich partnerów połączonych na stałe, w tym na oryginał. Szczerze mówiąc, takie zachowanie jest ogólnie przydatne, z wyjątkiem przypadków, w których chciałbyś mieć „stabilne źródło odniesienia” (modyfikacja 1-kierunkowa) Ta zmiana zostanie przeniesiona na wszystkich partnerów połączonych na stałe, w tym na oryginał. Szczerze mówiąc, takie zachowanie jest ogólnie przydatne, z wyjątkiem przypadków, w których chciałbyś mieć „stabilne źródło odniesienia” (modyfikacja 1-kierunkowa)
Testowałem kopiowanie pojedynczych linków twardych i folderów zawierających dowiązania twarde w Eksploratorze Windows, a wynik po prostu tworzy niepowiązane skróty do oryginalnych danych (nie są już powiązane twardymi linkami, a zatem nie zmieniają się wraz z modyfikacjami oryginalnego linku). Uważam, że brak prostego kopiowania jest bardzo irytujący, a główny powód niechętnie korzystam z nich w szerokim zakresie, ale jeśli masz tylko kilka do określonego celu (np. Synchronizowanie łączy ze stabilnego katalogu, z pulpitem / paskiem zadań) / startmenu) mogą nadal być dobrym rozwiązaniem (chociaż nie są tak naprawdę przenośne dla innych systemów, bez pisania skryptu w celu zautomatyzowania budowania katalogów). Oni jednak poruszają się bez przerwy (możesz je przenieść w dowolnym miejscu w systemie plików, gdy już zostaną utworzone. Po prostu nie możesz ich „skopiować”).
Aby utworzyć łącze twarde, wystarczy otworzyć wiersz polecenia z podwyższonym poziomem uprawnień (.cmd otwarty dla systemu32 lub uruchomić .cmd jako administrator) i wpisać:
Przykład:
Dobrze jest wyznaczyć hardlink z typem pliku, do którego prowadzi (np. Tutaj .lnk, ale w przypadku dokumentów notatnika hardlink.txt lub podobnym), ponieważ jest to w zasadzie odbicie lustrzane oryginalnego pliku, a Eksplorator Windows traktuje go tak, jakby były oryginalne (ponownie użyteczne zachowanie). Powinienem również bezpośrednio stwierdzić, że są one tworzone TYLKO za pomocą wiersza polecenia (lub oprogramowania innej firmy, które udostępnia polecenie shellExtension lub GUI) Nie są też kopią lustrzaną'oryginału, mogą pokazywać rozmiary plików oryginalnego obiektu, ale same w sobie zajmują 0 bajtów miejsca na dysku; w rzeczywistości są one zapisanymi odniesieniami do MFT dysku (co jest również powodem, dla którego nie można ich tworzyć między 2 różnymi partycjami [co jest kolejną cechą, o której warto wspomnieć, ale którą można łatwo pokonać za pomocą sprytnej kombinacji skrótów, skrzyżowań , dowiązania symboliczne i dowiązania twarde używane razem zgodnie]])
Szczerze mówiąc, wierzę, że jest to dokładnie to, czego szukasz i jest to bardzo przydatna funkcja. Jeśli potrafisz dobrze pisać, jestem pewien, że nie jest trudno napisać program, który po prostu buduje katalog dowiązania twardego, jak chcesz (i traktuje to jako „kopię zapasową” lub „rozwiązanie przenośności” dla innych systemów). Być może będziesz w stanie znaleźć oprogramowanie innych firm, które ułatwi wszystkie te zadania i przezwycięży wewnętrzną niechęć do pracy z linkami twardymi.
źródło
fc
z wiersza poleceń i napisano „nie napotkano różnic”Najprostszym obejściem byłoby użycie plików wsadowych .
Jeśli
Shortcut.lnk
znajduje się wC:\Files\
, utworzenie nowego.bat
pliku z następującym pojedynczym wierszem kodu spowoduje uruchomienie.lnk
pliku:źródło
.lnk
pliku musi być również.lnk
plikiem? Jeśli jest to ważne lub masz inne wymagania, edytuj swoje pytanie, aby uwzględnić te szczegóły. W ten sposób uzyskasz lepszą odpowiedź. :).bat
pliki były wystarczające, to Microsoft nie stworzyłby.lnk
plików ...