摘要: 在 Windows 注册表、批处理脚本或命令行中,「看似正确」的命令却莫名其妙地执行失败,大多数时候并非路径写错,而是被「不可见的 Unicode 控制字符」悄悄破坏。本文将带你一探究竟,并给出一劳永逸的解决方案。
注册表右键菜单失效
你在 HKEY_CLASSES_ROOT\SystemFileAssociations\.py\shell\…\command
下填入:
"D:\Scripts\run_python.bat" "%1"
明明写对了,结果右键菜单不出现、或点击后也不执行。
批处理参数莫名丢失 调用:
mytool.bat "C:\path\to\file.txt"
输出:
原始参数:[]
明明给了参数,脚本却收不到。
命令行报“找不到文件”
"C:\My Tools\tool.exe" --option
结果提示 “不是内部或外部命令,也不是可运行的程序。”
这些场景背后,绝大多数都是「看不见的控制字符」在作怪。
控制符名称 | 代码点 | 作用 |
---|---|---|
左到右嵌入 (LRE) | U+202A | 强制后续文本按 LTR 排版 |
右到左嵌入 (RLE) | U+202B | 强制后续文本按 RTL 排版 |
字节顺序标记[BOM] | U+FEFF | 标识文本编码 |
零宽度空格 | U+200B | 用于排版,不占位置 |
零宽度连字符 | U+200C/U+200D | 控制连字/文字合成 |
新建 detect.bat
:
@echo off
echo 原始参数:[%~1]
echo Hex Dump:
for /f "usebackq delims=" %%A in (`echo %~1 ^| xxd -g 1`) do echo %%A
pause
在命令行运行:
detect.bat "C:\path\to\script.bat"
如果输出首行出现诸如 e2 80 aa
(对应 U+202A),说明命令里混入了 LRE 控制符。
小贴士:
Windows 下可用 CertUtil:
echo command | certutil -encodehex -f -
Git for Windows 自带 xxd:更直观。
感悟: “在信息时代,复制–粘贴是双刃剑。它给你速度,却也可能暗藏无形的陷阱。下次当命令“看似正确却不起作用”时,请先问:有没有哪个零宽度的家伙在偷偷捣乱?”
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有