#ErrorStdOut

把任何阻止脚本运行的语法错误发送到标准错误(stderr), 而不是显示一个对话框.

#ErrorStdOut Encoding

参数

Encoding

类型: 字符串

如果省略, 它默认为 CP0(系统默认的 ANSI 代码页). 否则, 请指定编码字符串指示如何对输出进行编码. 例如, #ErrorStdOut UTF-8 将错误信息编码为 UTF-8 然后再发送到 stderr. 无论捕获输出的程序是什么, 都必须支持 UTF-8, 并且在某些情况下可能需要配置为期望 UTF-8.

注意: 这个参数不是一个表达式, 但可以用引号括起来(可以是 '单引号' 或 "双引号").

备注

如果脚本中没有指定该指令, 则会在对话框中显示语法错误.

错误被写入 stderr, 而不是 stdout. 命令行和高级编辑器往往会同时显示这些信息.

这个指令可以让诸如 TextPad, SciTE, Crimson 和 EditPlus 这些高级编辑器在语法错误发生时跳到有问题的行. 由于必须将 #ErrorStdOut 指令添加到脚本中, 所以通常最好设置编辑器使用命令行开关 /ErrorStdOut 来启动任何 AutoHotkey 脚本(详情请参阅下面的设置说明).

因为 AutoHotkey 不是控制台程序, 所以错误将不会直接出现在命令行中. 这可以通过以下方法解决 1) 使用 Ahk2Exe ConsoleApp 指令编译脚本, 或 2) 通过管道或重定向捕获脚本的输出. 例如:

"C:\Program Files\AutoHotkey\AutoHotkey.exe" /ErrorStdOut "My Script.ahk" 2>&1 |more
"C:\Program Files\AutoHotkey\AutoHotkey.exe" /ErrorStdOut "My Script.ahk" 2>"Syntax-Error Log.txt"

你还可以使用操作系统内置的 clip 命令将输出直接管道传输到剪贴板. 例如:

"C:\Program Files\AutoHotkey\AutoHotkey.exe" /ErrorStdOut "My Script.ahk" 2>&1 |clip

注意: 2>&1 将 stderr 重定向到 stdout, 而 2>Filename 只将 stderr 重定向到一个文件.

和其他指令一样, #ErrorStdOut 不能有条件地执行.

特定编辑器的设置说明

EditPlus:

  1. 在菜单栏选择 Tools(工具) > Configure User Tools(配置用户工具).
  2. 点击按钮: Add Tool(添加) > Program(应用程序)
  3. Menu Text(菜单文本): 你自己填写
  4. Command(命令): C:\Program Files\AutoHotkey\AutoHotkey.exe
  5. Argument(参数): /ErrorStdOut "$(FilePath)"
  6. Initial directory(初始目录): $(FileDir)
  7. Capture output(捕获输出): Yes

TextPad:

  1. 在菜单栏选择 Configure > Preferences.
  2. 展开 Tools(工具) 菜单.
  3. 点击 Add 按钮然后选择 "Program".
  4. 复制并粘贴(调整为您的 cmd.exe 路径): C:\Windows\System32\cmd.exe -- 然后点击 OK.
  5. 三击列表框中新添加的项(cmd.exe) 并将其重命名为您选择的自定义名称(如 Launch Script).
  6. 点击 Apply.
  7. 从左侧树列表中选择新增的项, 然后填写下列信息:
  8. Command(应该已经填好): cmd.exe(或者是它的完整路径)
  9. Parameters(调整为您的 AutoHotkey.exe 路径): /c ""C:\Program Files\AutoHotkey\AutoHotkey.exe" /ErrorStdOut "$File""
  10. Initial folder: $FileDir
  11. 选择下列框: 1) Run minimized; 2) Capture output.
  12. 点击 OK. 新添加的项就应该已经出现在 Tools 菜单中了.

FileAppend(因为它也可以发送文本到 stderr 或 stdout)

示例

发送任何阻止脚本启动的语法错误到 stderr, 而不是显示一个对话框.

#ErrorStdOut