我最近从Windows 8.1升级到Windows 10。
现在我想为Apache Maven的新安装设置一个环境变量。
每次我创建user变量时,事情都很好。然而,我还需要创建系统变量,我需要将bin目录附加到我已经在用户变量中创建的变量为“path”。
现在,每次我这样做,我都会得到一个错误,说“这个环境变量太大了”。因此,我无法创建路径。
我附上了这个错误的图片。
我最近从Windows 8.1升级到Windows 10。
现在我想为Apache Maven的新安装设置一个环境变量。
每次我创建user变量时,事情都很好。然而,我还需要创建系统变量,我需要将bin目录附加到我已经在用户变量中创建的变量为“path”。
现在,每次我这样做,我都会得到一个错误,说“这个环境变量太大了”。因此,我无法创建路径。
我附上了这个错误的图片。
当前回答
解决方法:使用编辑文本按钮并在文本编辑器中编辑您的PATH。
其他回答
有几种方法可以清理路径变量。最简单的是使用快速环境编辑器。这个免费的工具,
删除重复路径(右键单击→清除路径) 删除不存在的文件夹(如红色所示,需要手动删除) 将长路径替换为短路径(右键单击→长路径转换为短路径)。
我按顺序执行上述步骤,并仅对最长路径使用第三步,直到再次控制Path变量大小。
如果你想要更高级,这里有一个c#小工具,你可以修改为任何你想要实现的逻辑。
另一种绕过PATH环境可变长度限制的解决方案是使用PowerShell脚本管理路径(添加、删除或更新);
通过点击“编辑文本”(见上面的截图)捕获当前的PATH变量,并将其复制到剪贴板中,并将其保存在文本文件中作为备份,以避免糟糕的意外。这不是强制性的,但可以让您在出现问题时恢复。 现在它已经备份,将以下内容添加到一个新的PowerShell (.ps1)文件中(使用您想要添加的文件夹路径(+号后面的部分)修改下面的第一行:
$newPath = $env:Path + '; C:\Users\....\FirstFolderToAddToPath; C:\Users\....\SecondFolderToAddToPath;'
[Environment]::SetEnvironmentVariable("Path", $newPath, "Machine")
$env:Path = $newPath
这就是我在使用Windows 10 UI后如何设法获得我的(长)PATH变量,被长度限制捕获并丢失了大部分路径。
解决方法:使用编辑文本按钮并在文本编辑器中编辑您的PATH。
我发现这个AutoHotkey脚本很有用,用于编辑或添加到我的极长的路径(现在是3743个字符):
https://gist.github.com/roblogic/59898966f3ce594eb78a5b6147013194
(我不知道这么长的路会有什么后果;我可能还得修。)
除了Swapnil的答案之外,请注意,您可以修改Path环境变量的最大长度—否则将限制为2048个字符(而单个路径的历史限制为206个字符)。
在Windows 10中,你可以通过设置LongPathsEnabled注册表项为1来实现这一点,可以在这里找到:
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem
进入注册表编辑器:Windows键+ R,输入Regedit。
来源:Windows 10“启用NTFS长路径策略”选项缺失
也看看这个超级用户的答案:Windows 10“启用NTFS长路径策略”选项缺失的答案
请注意,错误“环境变量太大”与整个变量有关,而不是当前添加的单个路径(以回答下面的“不准确建议”评论)。
附加说明:应用程序兼容性
与LongPathsEnabled相关的注册表键/组策略中的文本如下:
启用NTFS长路径将允许明确的win32应用程序和Windows Store应用程序访问超出每个节点260字符限制的路径。启用此设置将使长路径在进程中可访问。
这里需要注意的是“显化”一词。一般来说,应用程序需要在清单文件中显式地声明功能;自Windows Vista时代以来,大多数win32应用程序都得到了体现。要使用长路径,应用程序清单需要一个longPathAware元素:
<application xmlns="urn:schemas-microsoft-com:asm.v3">
<windowsSettings xmlns:ws2="http://schemas.microsoft.com/SMI/2016/WindowsSettings">
<ws2:longPathAware>true</ws2:longPathAware>
</windowsSettings>
</application>
更多信息请点击这里。
一些用户抱怨Windows资源管理器和其他应用程序还不支持LongPathsEnabled,尽管通常可以找到可用的替代方案。例如,在这个论坛帖子中,一个用户声明
唯一支持长路径和长文件名的资源管理器是total commander。它还允许编辑文件名和打开/处理文件,如果接受应用程序也使用扩展API函数。 记事本似乎可以。MKVtoolnix。此外,非常令人惊讶的是,MPC-HC,尽管它还没有开发多年。毫不奇怪,糟糕的VLC没有(真的吗?),可爱的PotPlayer也没有。
超级用户对此也有一个有趣的讨论。特别地,这个答案描述了使用长路径的两种可行替代方案:使用Cygwin (*nix模拟层)或使用NTFS Junction Points(本质上是一个链接,像符号链接一样)分割长路径。