以下是一个示例代码,用于遍历指定的注册表子键:
import winreg
def enum_reg_keys(key, subkey):
try:
# 打开指定的注册表键
reg_key = winreg.OpenKey(key, subkey, 0, winreg.KEY_READ)
# 获取子键的个数和值的个数
num_of_subkeys = winreg.QueryInfoKey(reg_key)[0]
num_of_values = winreg.QueryInfoKey(reg_key)[1]
print(f"子键个数:{num_of_subkeys}")
print(f"值的个数:{num_of_values}")
# 遍历子键
for i in range(num_of_subkeys):
subkey_name = winreg.EnumKey(reg_key, i)
print(f"子键名:{subkey_name}")
# 关闭注册表键
winreg.CloseKey(reg_key)
except WindowsError as e:
print(f"无法打开注册表键:{e}")
# 要遍历的注册表根键
reg_root_key = winreg.HKEY_LOCAL_MACHINE
# 要遍历的注册表子键路径
reg_subkey_path = r"Software\Microsoft\Windows\CurrentVersion\Uninstall"
# 调用函数进行遍历
enum_reg_keys(reg_root_key, reg_subkey_path)
此示例中,我们使用winreg模块来操作注册表。enum_reg_keys函数接受一个注册表根键和一个子键路径作为参数,并在给定的子键中遍历所有的子键名。我们首先打开注册表键,然后使用QueryInfoKey函数获取子键的个数和值的个数。然后使用EnumKey函数遍历子键并打印它们的名字。最后,我们关闭注册表键。在主程序中,我们指定了要遍历的注册表根键和子键路径,并调用enum_reg_keys函数进行遍历。
上一篇:遍历制表符分隔的文件
下一篇:遍历指定路径的OrientDB