解决Windows超长路径问题

2021-02-27 10:25:53 电脑爱好者 2021年4期

平淡

了解文件夹路径长度限制的由来

文件(夹)路径是通过类似“D:\aa.txt”“D:\a”的形式表示的,如后者表示D盘下名为“a”的文件夹的路径。这里总共有4个字符(如果是中文名称,1个汉字是2个字符)。而在Windows API中,微软规定文件(夹)路径的最大长度是259个字符。不过在资源管理器中创建文件夹的时候还需要为8.3文件名保留12个字符,而在实际统计文件夹名称长度的时候需要扣除“驱动器:\”(如D:\)这3个字符。因此一个正常的文件(夹)名称路径部分的最大长度其实是259-3-12=244个字符。当我们试图在超过244个字符的文件夹下再创建子文件夹,或者在其中保存文件时,资源管理器就会提示目标路径太长而无法创建。而在旧版系统(如Windows 7)中试图删除超长路径下的文件时,系统则会提示“源路径太长”无法删除(图1)。

为了测试在Windows中是否真的存在这个限制,大家可以尝试在“D:\”下新建一个文件夹,并将其重命名为“1111……”(一直按1键直到不能输入为止),然后將文件名字符复制并粘贴到Word中,点击“审阅一字数统计”,可以看到文件名中总计有244个“1”,即“D:\”下最多只能创建244个字符的文件夹(图2)。

手动创建超过字符限制的文件夹

如上所述,Windows的文件(夹)路径长度是有限制的,如公司的开发人员现在需要创建“C:\Users\kaifa\AppData\Local\Temp\tfdbg_b1622n_7\_tfdbg_deVice_,job_localhost,replica_0,task_0,device_CPU_0\train_step\gradients\bi-Istm\bidirectional_rnn\fw\fw\whlle\TensorArrayWrite\TensorArrayWriteV3_grad\TensorArrayReadV3\qwertyu\sddsafdsafdd\guuur\jyuhti\hyudjiy”(总计267个字符,因字串太长,后续描述时统一使用“long路径”名称替代,实际使用时要输入原字符串),用于存放开发文件。启动到命令提示符窗口,在其中输入“md”,此时系统会提示“文件名或扩展名太长”的提示而无法成功创建(图3)。

如果要创建超过路径长度的文件夹,我们可以使用其他方法变通。因为Windows在计算文件(夹)路径的长度时,它是按照从父目录到子目录的方式依次计算的,比如已经创建“D:\1”文件夹,现在路径已经总计有4个字符了,那么在其下就最多还只能创建244-1-4=239(还需要为“\”保留一个字符)个字符长度的文件夹,依此类推。所以使用MD命令直接创建long文件夹会出错。但是如果我们通过先建立符合要求的文件夹结构,然后再依次更改上一级文件夹的名称即可绕过这个限制。

比如需要创建上述long文件夹,先将文件夹的名称复制到Word里,同上查看字符数,接着将“TensorArrayReadV3”后的路径依次改为“1\2\3\4\5”(对应原文中的5个文件夹名称),这样字符数总计只有235个,同上使用MD命令完成文件夹的创建。然后打开创建的文件夹,依次将5、4、3、2、1名称重命名为hyudjiy、jyuhti、guuur、sddsafdsafdd、qwertyu即可(图4)。

查找并删除超长路径的文件(夹)

如上所述,超长路径的文件夹会给日常使用带来不便,而且一些病毒也可能会通过创建超长路径文件夹的方法来隐藏自身。如果要找出这类文件(夹),可以使用“Path Length Checker”(https:∥github.com/deadlydog/PathLenathChecker/releases/tag/v1.8.2)。启动程序后在

“Starting Directory:”(开始目录)后输入需要查找的驱动器,如“D:\”,最小长度输入242,按下回车键开始搜索(图5)。

这样程序会找出“D:\”下所有路径长度超过242(合)字符的文件夹,我们可以根据文件夹的名称来判断是否是自己不需要的文件,对于Windows 10的用户,在搜索结果中右击并选择“Open directory in File Explorer”,可以在资源管理器中打开这类文件夹并删除。对于旧版系统则可以先点击“Copy Paths to Clipboard”(复制路径到剪贴板),然后启动命令提示符,使用“rd/s/q粘贴上述获得的路径”命令来删除(图6)。当然,对于自己需要访问的文件,也可以将其复制到更短的路径(如E:\)下,同时将其重命名为短名称,如“cfan.×××”,避免因路径太长而无法访问。