RegOpenKey(key, subkey, reserved, sam)
RegOpenKeyEx(key, subkey, reserved, sam)
两个函数的参数一样。参数含义如下:
l Key:必须为表1中列出的项。
l SubKey:要打开的子项。
l Reserved:必须为0。
l Sam:对打开的子项进行的 *** 作,包括win32con.KEY_ALL_ACCESS、敏斗win32con.KEY_READ、win32con.KEY_WRITE等
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
如 key=win32api.RegOpenKey(win32con.HKEY_CURRENT_USER,'Software',0,win32con.KEY_READ)
print key
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
2. 关闭注册表
RegCloseKey(key)
其参数只有一个,其含义如下:
l Key:已经打开的注册表项的句柄。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
如win32api.RegCloseKey(key)
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
3. 读取项值
RegQueryValue(key,subKey) 读取项的默认值
RegQueryValueEx(key,valueName) 读取某一项值
对于RegQueryValue,其参数含义如下:
l Key:已打开的注册表项的句柄。
l subKey:要 *** 作的子项。
对于RegQueryValueEx,其参数含义如下:
l Key:已经打开的注册表项的句柄。
l valueName:要读取的项值名称。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
import win32api
import win32con
# 打开“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项
>>>key = win32api.RegOpenKey(win32con.HKEY_LOCAL_MACHINE,
'SOFTWARE\\Microsoft\\Internet Explorer',0, win32con.KEY_ALL_ACCESS)
>>>win32api.RegQueryValue(key,'') # 读取项的默认值
'' # 输出为空,表示其默认值未设置
#读取项值名称为Version的项值数据,也就是Internet Explorer的版本
>>>win32api.RegQueryValueEx(key,'Version')
('6.0.2900.2180', 1)
>>>win32api.RegQueryInfoKey(key) # RegQueryInfoKey函数查询项的基本信息
(26, 7, 128178812229687500L) # 返回项的子项数目、项值数目,以及最后一次修改时间
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
4. 设置项值
RegSetValueEx(key,valueName,reserved,type,value) 要修改或重新设置注册表某一项的项值。如果项值存在,则修改该项值,如果不存在,则添加该项值。
RegSetValue(key,subKey,type,value) 设置项的默认值
对于RegSetValueEx,其参数含义如下:
l Key:要设置的项的句柄。
l valueName:备数要设置的项值名称。
l Reserved:保留,可以设为0。
l Type:项值的类型。
l Value:所要设置的值。
对于RegSetValue,其参数含义如下:
l Key:已经打仿拿首开的项的句柄。
l subKey:所要设置的子项。
l Type:项值的类型,必须为win32con.REG_SZ。
l Value:项值数据,为字符串。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
# 将“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”
的默认值设为python
>>>win32api.RegSetValue(key,'',win32con.REG_SZ,'python')
# 将其“Version”设置为7.0.2900.2180
>>>win32api.RegSetValueEx(key,'Version',0,win32con.REG_SZ,'7.0.2900.2180')
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
5. 添加、删除项
RegCreateKey(key,subKey) 向注册表中添加项
RegDeleteKey(key,subKey) 删除注册表中的项
其参数含义相同,参数含义分别如下:
l Key:已经打开的注册表项的句柄。
subKey:所要 *** 作(添加或删除)的子项。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
# 向“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”添加子项“Python”
>>>win32api.RegCreateKey(key,'Python')
# 新创建的子项的句柄
# 删除刚才创建的子项“Python”
>>>win32api.RegDeleteKey(key,'Python')
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
6. 错误处理
ImportError: No module named win32api出现异常
望采纳!
对注册表进行 *** 作前,必须打开锋肢橘注册表。在Python中,可以使用以下两个函数:RegOpenKey和RegOpenKeyEx。其函数原型分别如下所示。 Html代码 RegOpenKey(key, subKey , reserved , sam) RegOpenKeyEx(key, subKey , reserved , sam) 两个函数的参数一样。参数含义饥谈如下。 key:必须为表10-1中列出的项。 subKey:要打开的子项银团。 reserved:必须为0。 sam:对打开的子项进行的 *** 作,包括win32con.KEY_ALL_ACCESS、win32con.KEY_READ、win32con. KEY_WRITE等。 以下实例实现打开注册表“HKEY_CURRENT_USER\Software”项。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)