Как сократить путь к файлу через командную строку
1>. Обратите внимание, что я говорю о cmd, а когда я нахожусь в cmd и просматриваю файл и папки, а не в пакетном файле.
ОК, чтобы закончить все путаницы, это то, что я хочу:
C:Program Files> _
а другие было вокруг:
C:Program Files> _
C:Program Files> <command>
Я надеюсь, что теперь ясно xD.
развернуть и сократить путь к файлу текущего cmd
когда я в C:\PROGRA
1> я хотел бы расширить его до C:\Program Архив.> Также я хотела бы поменять наоборот, когда я в Файлы C:\Program > короткие его C:\PROGRA
1>. Обратите внимание, что я говорю о cmd и когда я в cmd и переживает файлов и папок, не в пакетном файле.
я подумал, что просто добавлю это в качестве ответа, чтобы расширить свой комментарий и помочь убедиться, что все понятно, о чем я говорил.
В Одну Сторону
так как вы делаете это из командной строки, а не из пакетного сценария, вот некоторые предложения.
используйте переменную окружения, чтобы каталог программных файлов как таковой: CD /D "%programfiles%"
после того, как в длинный путь с помощью выше переменной среды, введите или скопируйте и вставьте эту команду, чтобы перейти к короткому пути той же директории FOR %A IN (.) DO CD "%
переключение между двумя командами со стрелкой вверх и т. д. чтобы изменить между ними, так как вы делаете это из командной строки вручную, а не пакетный сценарий.
Другой Способ
вы можете просто сделать DIR /D /X команда, чтобы получить короткие пути к папкам, где это применимо, а затем сделать явный CD /D "C:\ShortPathName
" из CMD, чтобы перейти в этот каталог с коротким путем.
в другом направлении, вы можете сделать CD команда, но перед нажатием Enter нажмите Tab однако много раз вам нужно пройти через имена папок для длинных имен путей, которые заполняются автоматически.
Примечание: я не уверен на 100% с Tab ключ на XP для автоматического заполнения длинного пути имя папки, и у меня нет что-нибудь XP мудрое, чтобы проверить это прямо сейчас, но это некоторые быстрые идеи, которые у меня есть для того, что вы объясняете, и некоторые обходные пути.
Указать в bat-файле в качестве пути папку, в которой он находится
Помогите создать bat файл. В качеству пути должна указываться папка, в которой он находится. Сам.
Упрощение .bat скрипта
Доброго времени суток! Есть скрипт по скрыванию папок. Необходимо его упростить. В этом деле полный.
Вызов одного bat в другом bat файле несколько раз
Доброго времени суток. Подскажите: есть два бат-файла, установлена система radius, приходят архивы.
Можно ли получить имя bat-файла в этом же bat-файле?
Запускаю прогу со входными аргументами из батника. Последний аргумент - имя выходного файла. Хочу.
Но если надо будет работать с подпапками, то могут возникнуть трудности. Еще как вариант можно положить рядом с батником файл rar.exe и путь к нему указывать V1RTuE интересные варианты, а можно по подробнее, как первый так и второй, дело в том что архивация будет происходить раз в день, в одной папке, единственное что это папка может лежать где угодна ну или почти, или на рабочем столе или в Program Files(стандартно). ASSEI, Архивация всех файлов (кроме батника) в текущей папке и подпапках. В самом архиве подпапок не будет.
Добавлено через 5 минут
А на счет второго варианта, то из папки C:\Program Files\WinRAR\ скопируй файл Rar.exe. И в дальнейшем указывай путь до него (можно поместить в любое место, например, рядом с батником и уже указывать относительный путь). Установки не требуется и работать будет на любом компе.
шикарно что ничего не понятно(ну да ладно до этого мне далеко) ))) а куда бы пихнуть дату перед именем архива?
Добавлено через 8 минут
хотя второй вариант мне больше понравился, но первый ваш работает быстрее
непонятно почему код выглядит именно так? или непонятно куда вставить этот код в свой батник? ой ой а я только увидел архив то создается не один раз, а хотелось бы что бы в одном экземпляре, в вашем коде происходит создание архива в архиве, моя суть заключалась в том что бы архив создавался бы один раз нюанс в том что бы заносить файлы в архив и если одинаковый то менять его на последний.
ASSEI, а в чем смысл такого архивирования? обычно если делается архив, то, во-первых, он помещается на другой носитель (или в облако отправляется), во-вторых, при появлении новых данных в папке, то просто создается новый архив. А то мало ли что.
Может проще дописать в батник путь, куда будет перемещен архив? и на сколько объемный будет у вас архив?
Описание проблемы длинных путей
Раньше имена файлов в Windows ограничивались форматом 8.3 - всего восемь символов для имени файла и три для расширения. С появлением Windows 95 Microsoft сняла этот предел и позволила использовать гораздо более длинные имена.
Тем не менее, файловая система Windows по-прежнему накладывает некоторые ограничения, например, какие символы могут использоваться в именах файлов и общую длину путей. Некоторое время максимальная длина пути составляла 260 символов, но с появлением Windows 10, часть ограничений начала потихоньку уходить, например для приложений и появилась возможность отключить проверку MAX_PATH и использовать длинные пути без префикса \\?\.
Что интересно, значение в 260 символов обусловлено значением MAX_PATH Win32 API. У файловой системы NTFS максимальная длина пути ″немного″ больше и составляет 32767 символа. Для обхода ограничений Win32 API некоторые приложения используют формат UNC, указывая абсолютный путь с префиксом \\?\, например так:
Хочу отметить, что на период ноября 2020 года и последней версий Windows 10 1909, в ПРОВОДНИКЕ Windows до сих пор есть ограничения в 260 символов, и мы все слышим обещания, что их исправятБольшинство людей может и не столкнуться с ней, а вот почти каждый системный администратор обязательно это увидит. Тут все дело в том, что в большинстве организаций есть свои сетевые файловые ресурсы, через которые пользователи производят обмен и работу с документами. В какой-то момент люди могут создать такой путь, который будет 258 или 260 символов, попытаются туда скопировать файл, а им выдастся ошибка:
Слишком длинный целевой путь: Имена файлов слишком длинны для помещения в эту целевую папку. Попробуйте использовать более короткое имя имя файла или расположение с более коротким путемТоже самое при копировании в папку, так же выскакивает "Слишком длинный целевой путь".
Вот ошибка при извлечении архива в сетевую папку:
Не удается завершить извлечение. Слишком длинный конечный путь. Переименуйте сжатую ZIP-папку и повторите попыткуМетоды снимающие ограничения на длину пути в Windows
- Через групповую или локальную политику Windows (Применимо только к Windows 10 и Windows Server 2016 и выше)
- Через реестр Windows (Применимо только к Windows 10 и Windows Server 2016 и выше)
- Через сторонние утилиты 7-Zip, Far, TotalCommander (Применимо ко всем версиям Windows)
- Использование силинков (символических ссылок) (Применимо ко всем версиям Windows)
- Через сетевой диск, для укорачивания пути
- Утилиты xcopy, robocopy
Нюансы длинных путей в приложениях
Есть один нюанс. Этот новый параметр (имеется ввиду та политика и ключ реестра) не обязательно будет работать со всеми существующими приложениями, но он будет работать с большинством. В частности, любые современные приложения должны работать нормально, как и все 64-битные приложения. Старые 32-разрядные приложения должны быть применимы для работы, что на самом деле просто означает, что разработчик указал в файле манифеста приложения, что приложение поддерживает более длинные пути. Большинство популярных 32-битных приложений не должно вызывать проблем. Тем не менее, вы ничем не рискуете, пробуя настройку. Если приложение не работает, единственное, что произойдет, это то, что оно не сможет открывать или сохранять файлы, сохраненные в местах, где полный путь превышает 260 символов.
Если вы разработчик, то чтобы ваше приложение имело возможность работать с длинными путями Windows, в манифесте обязательно указывайте следующие настройки:
<application xmlns="urn:schemas-microsoft-com:asm.v3"><windowsSettings>
<longPathAware xmlns="http://schemas.microsoft.com/SMI/2016/WindowsSettings">true</longPathAware>
</windowsSettings>
</application>
Как в Windows 10 отключить ограничение на длину пути в 260 символов через политику
Чем примечателен данный метод, так это тем, что неподготовленных пользователей он не вынуждает выполнять команды или производить правку реестра, тут все в графическом виде. Так же если у вас есть домен Active Directory и вы хотите массово убрать ошибки "Слишком длинный целевой путь" или "Слишком длинный конечный путь" в приложениях и запретить им проверять MAX_PATH и использовать длинные пути без префикса \\?\, то групповые политики вам это помогут.
Еще раз напоминаю, что данный метод подойдет и для серверных версий, даже самых современных Windows Server 2019Покажу для начала, как делать через локальную политику, открываете окно "Выполнить" в котором пишите gpedit.msc.
Хочу отметить, что для Windows 10 Home данный метод работать не будет, там просто нет редактора локальных политик, там придется лезть в реестр WindowsДалее идем по пути:
Конфигурация компьютера - Административные шаблоны - Система - Файловая система (Computer configuration - Administrative templates - System - Filesystem)Найдите тут параметр "Включить длинные пути Win32 (Enable Win32 long paths)", по умолчанию он отключен, и я честно не понимаю почему. Активируйте его.
Как я писал выше, в проводнике это не даст ни каких эффектов, поэтому вы все так же будите получать ошибку при копировании, создании, удалении "Слишком длинный целевой путь" или "Слишком длинный конечный путь". Ниже я покажу, что делать если нужно что-то там удалить или изменить. Данное ограничение в длине пути теперь не подхватиться на лету всеми приложениями, потребуется перезагрузка.
Включение поддержки длинных путей через реестр
Данный метод ни чуть не сложнее предыдущего и делает все то же самое, включает поддержку длинных путей свыше 256 символов для приложений Windows. Когда вы что-то меняете через редактор политик, по сути меняются настройки в реестре, это нужно помнить и знать. Сейчас я вам покажу какой ключ меняется. Откройте редактор реестра Windows. Перейдите в раздел:
тут вам необходимо найти параметр LongPathEnabled, которому для активации поддержки длинных путей и изменения ограничений в MAX_PATH, нужно задать значение "1". Тут потребуется перезагрузка.
Все что вам нужно, это распаковать zip-архив и запустить нужный файл активации, потом так же перезагрузиться, так как у вас будет создан нужный ключ реестра, без необходимости лезть в реестр самостоятельно.
Еще вы можете сделать такую поддержку и для конкретного пользователя по пути:
Если там нет ключа LongPathsEnabled, то создайте его, тип DWORD (32 бита) и значение 1.
Как в Windows 10 отключить ограничение на длину пути в 260 символов через PowerShell
Не все люди готовы копаться в редакторах и реестрах, им нужно быстрое решение, одним из таких является PowerShell. В оболочке выполните команду для активации параметра "Включить длинные пути Win32 (LongPathEnabled)". Не забываем перезагрузить систему.
Set-ItemProperty -Path HKLM:\SYSTEM\CurrentControlSet\Control\FileSystem -Name LongPathsEnabled -Value 1Как удалять, копировать, переносить файлы и папки при ошибке с длинными путями
Разобравшись с тем, как отключить проверку MAX_PATH в приложениях, давайте теперь поймем и научимся решать проблему длинных путей на файловых шарах и просто в проводнике. Классическая ситуация, когда пользователь попытался перенести свой файл или удалить его, создать папку и так далее, и он получает ошибку с пресловутыми длинными путями. Он просит разобраться вас и тут начинаются танцы с бубнами, вы просите его либо переименовать часть пути, или попросить его произвести действия в другом расположении, или просто забить, сказав, что виновата Windows со своими ограничениями, но мы же с вами профессионалы и инженеры, поэтому должны уметь выходить из таких ситуаций.
Как в Windows 10 отключить ограничение на длину пути в 260 символов через командную строку
Запустите командную строку в режиме администратора и введите:
reg add "HKLM\SYSTEM\CurrentControlSet\Control\FileSystem" /v LongPathsEnabled /t REG_DWORD /d 1Обход ограничений длинных путей через 7zFM
Откройте 7zFM.exe и перейдите в нем в конечную папку вашего пути.
Для создания новой папки нажмите клавишу F7.
Задайте необходимое вам имя, в моем примере это будет "БОльше 260 Microsot".
В результате у нас создалась новая папка и заметьте 7zFM не ругнулся на наличие длинных путей, он их игнорирует просто и все.
Проверяем, что директория доступна через проводник Windows.
Все прекрасно отображается. Теперь я думаю вы легко сможете переносить, копировать, удалять файлы через 7zFM, когда вам проводник Windows ругается на наличие длинных путей.
Как обойти ограничение длинных путей через символьную ссылку
Такой трюк мы с вами уже проделывали, когда нужно было переносить IMAP профиль у Outlook. Смысл в том, что создается файл в нужном вам месте, и этот файл это просто ярлык ссылающийся на нужный вам файл или папку, после этого путь сокращается и вы можете удалять или создавать все что вам нужно. Откройте командную строку, далее вам нужно иметь два составляющих:
- Путь где будет лежать файл символической ссылки - в моем примере C:\короткий путь
- Длинный путь - C:\Share\WINDOW
Нам поможет команда mklink, где ключ /D создает ссылку на каталог
Символическая ссылка успешно создана, можно проверять.
Откройте каталог с укороченным путем и попробуйте создать просто папку, в итоге она будет создана именно по тому длинному пути, как видите легко можно обходить ограничение в 260 символов.
Как обойти ограничение длинных путей через сопоставление subst
subst - простая команда позволяющая связать нужный путь к каталогу с буквой диска. Так же откройте командную строку в режиме администратора и сопоставьте ваш длинный путь с буквой W.
У вас в проводнике Windows должен появиться диск с данной буквой, если его нет, то прочитайте статью "Не появляется диск после команды subst" или просто в проводнике вбейте W:\ и нажмите Enter.
Как обойти ограничение длинных путей через монтирование сетевого диска
В командной строке используйте команду net use, далее буква диска, которую мы присваиваем и в самом конце путь:
Как видим все прекрасно отработало и диск появился.
Использование утилит Far или Total Commander
После включения параметра "Включить длинные пути Win32" данные утилиты в 100% случаев помог вам произвести любые действия с папками или файлами на любом длинном пути в системе Windows. Откройте Total Commander и создайте для примера папку в каталоге с длинным путем, напоминаю для этого нужно нажать F7.
Как видите все прекрасно создается, удаляется или копируется при желании.
1>. Обратите внимание, что я говорю о cmd, а когда я в cmd и прохожу файлы и папки, а не пакетный файл.
ОК, чтобы положить конец всей неразберихе, вот чего я хочу:
C:\Program Files> _
И другие были вокруг:
C:\Program Files> _
C:\Program Files> <command>
Надеюсь теперь понятно xD.
1 ответ 1
1>, я хотел бы расширить его до C:\Program Files>. Также я хотел бы изменить другой путь, когда я нахожусь в C:\Program Files>, чтобы сократить его до C:\PROGRA
Я подумал, что просто добавлю это в качестве ответа, чтобы расширить свой комментарий и помочь убедиться в том, что все понятно.
Одностороннее движение
Поскольку вы делаете это из командной строки, а не из пакетного скрипта, вот несколько советов.
Используйте переменную окружения, чтобы развернуть длинный путь к каталогу программных файлов следующим образом: CD /D "%programfiles%"
В длинном пути, используя указанную выше переменную среды, введите или скопируйте и вставьте эту команду, чтобы перейти к короткому пути в том же каталоге. FOR %A IN (.) DO CD "%
Переключайтесь между двумя командами с помощью стрелки вверх и т.д., Чтобы переключаться между ними, поскольку вы делаете это из командной строки вручную, а не с помощью пакетного сценария.
По-другому
Вы можете просто выполнить команду DIR /D /X чтобы получить краткие пути к папкам, в которых это применимо, а затем выполнить явный CD /D "C:\ShortPathName
" из CMD, чтобы перейти в этот каталог с коротким путем. название.
В другом направлении вы можете выполнить команду CD но перед тем, как нажать Enter, просто нажмите клавишу Tab, однако много раз вам нужно просматривать имена папок для длинных путей, которые автоматически заполняются.
ПРИМЕЧАНИЕ. Я не уверен на 100% с помощью клавиши Tab в XP для автоматического заполнения имени папки с длинным путем, и у меня нет ничего более разумного в XP, чтобы протестировать его прямо сейчас, но вот несколько быстрых идей, которые у меня есть для чего Вы объясняете и некоторые обходные пути.
Читайте также: