本文目录一览:
- 1、如何使用python修改注册表
- 2、如何使用 Python 访问注册表
- 3、如何在wi10注册表找到python位置
- 4、Python代码来读取注册表问题,怎么解决
- 5、如何使用python或c++访问注册表并修改系统变量path的值?
- 6、python里面的注册表怎么进去
如何使用python修改注册表
1. 打开注册表
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 访问注册表
对注册表进行操作前,必须打开注册表。在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”项。
如何在wi10注册表找到python位置
对注册表进行操作前,必须打开注册表。在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”项。
Python代码来读取注册表问题,怎么解决
windows上的python有内置模块winreg用于操作注册表,其文档可以在 开始所有程序PythonPython Module Docs中找到
如何使用python或c++访问注册表并修改系统变量path的值?
python为例,修改path的值为xxxxxx
import os
os.environ['Path'] = 'xxxxxx'
python里面的注册表怎么进去
在Python的标准库中,_winreg.pyd可以操作Windows的注册表,另外第三方的win32库封装了大量的Windows API,使用起来也很方便。不过这里介绍的是使用_winreg操作注册表,毕竟是Python自带的标准库,无需安装第三方库。
下面的例子是通过Python获取Windows
XP下已经安装的补丁号。Windows的补丁号都在“HKEY_LOCAL_MACHINE\SOFTWARE\\Microsoft
\\Updates”下,通过循环下面所有的目录节点,如果找到的名称符合正则表达式KB(\d{6}).*,则表示是一个补丁号。
从例子可以看出操作起来非常的简单和快速。
复制代码 代码如下:
# -*- coding: utf-8 -*-
# 获取Windows的已打的补丁号
from _winreg import *
import re
def subRegKey(key, pattern, patchlist):
# 个数
count = QueryInfoKey(key)[0]
for index in range(count):
# 获取标题
name = EnumKey(key, index)
result = patch.match(name)
if result:
patchlist.append(result.group(1))
sub = OpenKey(key, name)
subRegKey(sub, pattern, patchlist)
CloseKey(sub)
if __name__ == '__main__':
patchlist = []
updates = 'SOFTWARE\\Microsoft\\Updates'
patch = re.compile('(KB\d{6}).*')
key = OpenKey(HKEY_LOCAL_MACHINE, updates)
subRegKey(key, patch, patchlist)
print 'Count: ' + str(len(patchlist))
for p in patchlist:
print p
CloseKey(key)
下面内容转自 Python Standard Library12.13 The _winreg Module
(Windows
only, New in 2.0) The _winreg module provides a basic interface to the
Windows registry database. Example 12-17 demonstrates the module.
Example 12-17. Using the _winreg Module
File: winreg-example-1.py
复制代码 代码如下:
import _winreg
explorer = _winreg.OpenKey(
_winreg.HKEY_CURRENT_USER,
"Software\\Microsoft\\Windows\CurrentVersion\\Explorer"
)
#list values owned by this registry key
try:
i = 0
while 1:
name, value, type= _winreg.EnumValue(explorer, i)
print repr(name),
i += 1
except WindowsError:
value, type = _winreg.QueryValueEx(explorer, "Logon User Name")
print "user is", repr(value)
'Logon User Name' 'CleanShutdown' 'ShellState' 'Shutdown Setting'
'Reason Setting' 'FaultCount' 'FaultTime' 'IconUnderline'...
user is u'Effbot'