我正在尝试在Python中使用WinReg,但遇到了障碍。以下代码应该为每个返回的条目返回一个包含key:value的字典,我发现自己得到了相同的key:value。
如何编辑此代码以获得不同的值?
import _winreg
def subkeys(key):
i = 0
while True:
try:
subkey = _winreg.EnumKey(key, i)
yield subkey
i+=1
except WindowsError as e:
break
def traverse_registry_tree(hkey, keypath, tabs=0):
reg_dict = {}
key = _winreg.OpenKey(hkey, keypath, 0, _winreg.KEY_READ)
for subkeyname in subkeys(key):
reg_dict[subkeyname] = subkeyname
return reg_dict
keypath = r"SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall"
print traverse_registry_tree(_winreg.HKEY_LOCAL_MACHINE, keypath)
输出类似于以下内容:
{'Mozilla Firefox 40.0.2 (x86 en-US)': 'Mozilla Firefox 40.0.2 (x86 en-US)', 'IE40': 'IE40', 'Connection Manager': 'Connection Manager'}
任何帮助将不胜感激,请记住我无论如何都不是高级pythonist。
最佳答案
每次递归到traverse_registry_tree
函数时,都会创建一个新字典。因此,每本词典中只有一个键。
您可以说这是错误的,因为在递归调用中您不对返回值做任何事情:外部调用将打印返回值,而内部调用则不打印返回值。
您可以通过将递归调用的返回值打包到正在创建的字典中来解决此问题。但这并不像将整个词典传入和传出递归调用那样有效:
def traverse_registry_tree(hkey, keypath, reg_dict):
key = _winreg.OpenKey(hkey, keypath, 0, _winreg.KEY_READ)
reg_dict[keypath] = key
for subkey in subkeys(key):
subkeypath = "%s\\%s" % (keypath, subkey)
traverse_registry_tree(hkey, subkeypath, reg_dict)
reg_dict = {}
keypath = r"SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall"
traverse_registry_tree(_winreg.HKEY_LOCAL_MACHINE, keypath, reg_dict)
print(reg_dict)
不确定是否还要询问如何访问注册表值(以及键)?如果是这样,也有一些代码可以做到这一点:
def get_values(key):
key_dict = {}
i = 0
while True:
try:
subvalue = _winreg.EnumValue(key, i)
except WindowsError as e:
break
key_dict[subvalue[0]] = subvalue[1:]
i+=1
return key_dict
def traverse_registry_tree(hkey, keypath, reg_dict):
key = _winreg.OpenKey(hkey, keypath, 0, _winreg.KEY_READ)
reg_dict[keypath] = get_values(key)
for subkey in subkeys(key):
subkeypath = "%s\\%s" % (keypath, subkey)
traverse_registry_tree(hkey, subkeypath, reg_dict)
关于python - Python-Winreg获取键值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32171448/