from _winreg import *
"""print r"*** Reading from SOFTWARE\Microsoft\Windows\CurrentVersion\Run ***" """
aReg = ConnectRegistry(None,HKEY_LOCAL_MACHINE)
aKey = OpenKey(aReg, r"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall")
for i in range(1024):
try:
asubkey=EnumKey(aKey,i)
val=QueryValueEx(asubkey, "DisplayName")
print val
except EnvironmentError:
break
誰かがエラーを修正してください... HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstallキーのサブキー内に「DisplayName」を表示したいだけですこれは私が取得したエラーです。
Traceback (most recent call last):
File "C:/Python25/ReadRegistry", line 10, in <module>
val=QueryValueEx(asubkey, "DisplayName")
TypeError: The object is not a PyHKEY object
Documentation は、EnumKey
がキーの名前を含む文字列を返すことを示しています。 _winreg.OpenKey
関数で明示的に開く必要があります。コードスニペットを修正しました:
from _winreg import *
aKey = r"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall"
aReg = ConnectRegistry(None,HKEY_LOCAL_MACHINE)
print r"*** Reading from %s ***" % aKey
aKey = OpenKey(aReg, aKey)
for i in range(1024):
try:
asubkey_name=EnumKey(aKey,i)
asubkey=OpenKey(aKey,asubkey_name)
val=QueryValueEx(asubkey, "DisplayName")
print val
except EnvironmentError:
break
すべてのキーが「DisplayName」値を使用できるわけではないことに注意してください。
X64上のx86はどうですか? 使用64ビット固有タイプ
[アンインストール]に1024を超えるサブキーがある場合はどうなりますか? se_ winreg.QueryInfoKey(key) を使用します
Python 2:
import errno, os, _winreg
proc_Arch = os.environ['PROCESSOR_ARCHITECTURE'].lower()
proc_Arch64 = os.environ['PROCESSOR_ARCHITEW6432'].lower()
if proc_Arch == 'x86' and not proc_Arch64:
Arch_keys = {0}
Elif proc_Arch == 'x86' or proc_Arch == 'AMD64':
Arch_keys = {_winreg.KEY_WOW64_32KEY, _winreg.KEY_WOW64_64KEY}
else:
raise Exception("Unhandled Arch: %s" % proc_Arch)
for Arch_key in Arch_keys:
key = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE, r"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall", 0, _winreg.KEY_READ | Arch_key)
for i in xrange(0, _winreg.QueryInfoKey(key)[0]):
skey_name = _winreg.EnumKey(key, i)
skey = _winreg.OpenKey(key, skey_name)
try:
print _winreg.QueryValueEx(skey, 'DisplayName')[0]
except OSError as e:
if e.errno == errno.ENOENT:
# DisplayName doesn't exist in this skey
pass
finally:
skey.Close()
Python 3:
import errno, os, winreg
proc_Arch = os.environ['PROCESSOR_ARCHITECTURE'].lower()
proc_Arch64 = os.environ['PROCESSOR_ARCHITEW6432'].lower()
if proc_Arch == 'x86' and not proc_Arch64:
Arch_keys = {0}
Elif proc_Arch == 'x86' or proc_Arch == 'AMD64':
Arch_keys = {winreg.KEY_WOW64_32KEY, winreg.KEY_WOW64_64KEY}
else:
raise Exception("Unhandled Arch: %s" % proc_Arch)
for Arch_key in Arch_keys:
key = winreg.OpenKey(winreg.HKEY_LOCAL_MACHINE, r"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall", 0, winreg.KEY_READ | Arch_key)
for i in range(0, winreg.QueryInfoKey(key)[0]):
skey_name = winreg.EnumKey(key, i)
skey = winreg.OpenKey(key, skey_name)
try:
print(winreg.QueryValueEx(skey, 'DisplayName')[0])
except OSError as e:
if e.errno == errno.ENOENT:
# DisplayName doesn't exist in this skey
pass
finally:
skey.Close()
_ winreg.QueryValueEx のドキュメントに記載されているように、すでに開いているキーを渡す必要があります。 EnumKey は、開いているキーではなく文字列を返します。
aReg = ConnectRegistry(None,HKEY_LOCAL_MACHINE)
aKey = OpenKey(aReg, r"SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall")
for i in range(1024):
try:
keyname = EnumKey(aKey, i)
asubkey = OpenKey(aKey, keyname)
val = QueryValueEx(asubkey, "DisplayName")
print val
except WindowsError:
break
簡略化した_winreg
特定のレジストリキーのネストされた値をクエリする機能。
たとえば、これは、質問したレジストリキーをクエリするのがいかに簡単であるかです。
key = r'HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall'
for sub_key in get_sub_keys(key):
path = join(key, sub_key)
value = get_values(path, ['DisplayName', 'DisplayVersion', 'InstallDate'])
if value:
print value
出力
{'DisplayVersion': u'347.25', 'DisplayName': u'NVIDIA Control Panel 347.25', 'InstallDate': u'20150125'}
{'DisplayVersion': u'347.25', 'DisplayName': u'NVIDIA Graphics Driver 347.25', 'InstallDate': u'20150125'}
{'DisplayVersion': u'2.2.2', 'DisplayName': u'NVIDIA GeForce Experience 2.2.2', 'InstallDate': u'20150212'}
...
これらのユーティリティ関数も追加します。
from _winreg import *
import os
roots_hives = {
"HKEY_CLASSES_ROOT": HKEY_CLASSES_ROOT,
"HKEY_CURRENT_USER": HKEY_CURRENT_USER,
"HKEY_LOCAL_MACHINE": HKEY_LOCAL_MACHINE,
"HKEY_USERS": HKEY_USERS,
"HKEY_PERFORMANCE_DATA": HKEY_PERFORMANCE_DATA,
"HKEY_CURRENT_CONFIG": HKEY_CURRENT_CONFIG,
"HKEY_DYN_DATA": HKEY_DYN_DATA
}
def parse_key(key):
key = key.upper()
parts = key.split('\\')
root_Hive_name = parts[0]
root_Hive = roots_hives.get(root_Hive_name)
partial_key = '\\'.join(parts[1:])
if not root_Hive:
raise Exception('root Hive "{}" was not found'.format(root_Hive_name))
return partial_key, root_Hive
def get_sub_keys(key):
partial_key, root_Hive = parse_key(key)
with ConnectRegistry(None, root_Hive) as reg:
with OpenKey(reg, partial_key) as key_object:
sub_keys_count, values_count, last_modified = QueryInfoKey(key_object)
try:
for i in range(sub_keys_count):
sub_key_name = EnumKey(key_object, i)
yield sub_key_name
except WindowsError:
pass
def get_values(key, fields):
partial_key, root_Hive = parse_key(key)
with ConnectRegistry(None, root_Hive) as reg:
with OpenKey(reg, partial_key) as key_object:
data = {}
for field in fields:
try:
value, type = QueryValueEx(key_object, field)
data[field] = value
except WindowsError:
pass
return data
def get_value(key, field):
values = get_values(key, [field])
return values.get(field)
def join(path, *paths):
path = path.strip('/\\')
paths = map(lambda x: x.strip('/\\'), paths)
paths = list(paths)
result = os.path.join(path, *paths)
result = result.replace('/', '\\')
return result
レジストリ内のサブキーのリストを生成する簡単なプログラムを作成しました。現在、特定のサブキーについてそのリストを検索し、そこにない場合はそれらを追加する方法、および/または値を変更する方法を理解しようとしています。 (それほど難しくないはずです)これは私が思いついたものです。私はそれが役に立てば幸いです、またそれを遠慮なく批評してください:
from winreg import *
registry = ConnectRegistry(None, HKEY_LOCAL_MACHINE)
def openRegistryA():
rawKeyA = OpenKey(registry, "SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System")
try:
i = 0
while 1:
name, value, type = EnumValue(rawKeyA, i)
print(name, value, i)
i += 1
except WindowsError:
print("END")
CloseKey(rawKeyA)
def openRegistryB():
rawKeyB = OpenKey(registry, "SYSTEM\CurrentControlSet\Services\LanmanServer\Parameters")
try:
i = 0
while 1:
name, value, type = EnumValue(rawKeyB, i)
print(name, value, i)
i += 1
except WindowsError:
print("END")
CloseKey(rawKeyB)
openRegistryA()
openRegistryB()