从注册表读取值.
Value := RegRead(KeyName, ValueName, Default)
类型: 字符串
注册表键的全名, 例如 "HKLM\Software\SomeApplication"
.
必须以 HKEY_LOCAL_MACHINE(或 HKLM), HKEY_USERS(或 HKU), HKEY_CURRENT_USER(或 HKCU), HKEY_CLASSES_ROOT(或 HKCR) 或 HKEY_CURRENT_CONFIG(或 HKCC) 开始.
要访问远程注册表, 请在前面加上计算机名和反斜杠, 例如 "\\workstation01\HKLM"
.
只有在注册表循环时, 才能省略 KeyName, 在这种情况下, 默认为当前循环项目的键. 如果项目是子键, 则默认使用该子键的全名. 如果项目是值, 则 ValueName 默认为该值的名称, 但是可以被重写.
类型: 字符串
如果为空或省略, 将删除键的默认值(除了上面提到的), 这是 RegEdit 中显示为 "(默认)". 否则, 请指定将检索值的名称. 如果没有默认值(即注册表中显示 "数值未设置"), 则抛出一个 OSError.
类型: Any
如果省略, 则抛出 OSError, 而不是返回默认值. 否则, 如果指定的键或值不存在, 请指定要返回的值.
函数返回指定注册表键的值.
如果遇到问题(如不存在的键或值且省略 Default, 或权限错误), 则抛出 OSError.
A_LastError 被设置为操作系统 GetLastError() 函数返回的结果.
目前只支持以下值类型: REG_SZ, REG_EXPAND_SZ, REG_MULTI_SZ, REG_DWORD 和 REG_BINARY.
在注册表中, REG_DWORD 值总是被转换为正十进制数. 如果数字是负数, 则使用 OutputVar := OutputVar << 32 >> 32
或类似的方法将其转换为有符号的 32 位整数.
读取 REG_BINARY 键时, 结果是一串十六进制字符. 例如, REG_BINARY 值 01,a9,ff,77 的读取结果为字符串 01A9FF77.
读取 REG_MULTI_SZ 值的每个部分会以换行符结束(`n). 如果值为空, 则返回空字符串. 从返回值中逐个提取单独的部分, use a parsing loop.
要检索和操作多个注册表键或值, 请考虑使用注册表循环.
有关如何访问远程计算机注册表的详情, 请参阅注册表循环中的备注.
从 32 位脚本中读取或写入注册表的 64 位部分中的条目, 反之亦然, 请使用 SetRegView.
RegCreateKey, RegDelete, RegDeleteKey, RegWrite, 注册表循环, SetRegView, IniRead
TestValue := RegRead("HKEY_LOCAL_MACHINE\Software\SomeApplication", "TestValue")
检索并报告 "Program Files"(程序文件) 目录的路径. 有关另一种方法, 请参阅 EnvGet 示例 #2.
; 此行确保在 64 位系统上运行非 64 位脚本时 ; 也能正常返回 64 位的 Program Files 目录路径. SetRegView 64 ProgramFilesDir := RegRead("HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion", "ProgramFilesDir") MsgBox "Program files are in: " ProgramFilesDir