与注册表操作相关的函数可以分为打开注册表、关闭注册表、读取项值、c添加项值、添加项,以及删除项等几类。
1.打开注册表
对注册表进行操作前,必须打开注册表。在Python中,可以使用以下两个函数:RegOpenKey和RegOpenKeyEx。其函数原型分别如下所示。
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”项。
>>> import win32api # 导入win32api模块
>>> import win32con # 导入win32con模块
# 使用RegOpenKey打开注册表项
>>> key = win32api.RegOpenKey(win32con.HKEY_CURRENT_USER,
'Software',0,win32con.KEY_READ)
>>> print key # key为打开的项的句柄
2.关闭注册表
打开的注册表,在操作完成后,需要关闭。在Python中使用RegCloseKey函数关闭打开的注册表项。其函数原型如下所示。
RegCloseKey(key)
其参数只有一个,其含义如下。
key:已经打开的注册表项。
以下实例关闭一个已经打开的注册表项。
# 关闭刚才打开的注册表项
>>> win32api.RegCloseKey(key)
>>> print key
3.读取项值
在打开注册表项以后,可以使用RegQueryValue函数读取项的默认值。如果要读取某一项值,可以使用RegQueryValueEx函数。其函数原型分别如下所示。
RegQueryValue(key, subKey )
RegQueryValueEx(key, valueName )
对于RegQueryValue,其参数含义如下。
key:已打开的注册表项的句柄。
subKey:要操作的子项。
对于RegQueryValueEx,其参数含义如下。
key:已经打开的注册表项的句柄。
valueName:要读取的项值名称。
以下实例实现对“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项的操作。
>>> 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函数,如果要设置项的默认值可以使用RegSetValue函数。需要说明的是,对于RegSetValueEx,如果要设置的项值不存在,那么RegSetValueEx会添加该项值,如果存在,则修改该项值。其函数原型分别如下所示。
RegSetValueEx(key, valueName, reserved, type, value)
RegSetValue(key, subKey, type, value)
对于RegSetValueEx,其参数含义如下。
key:要设置的项的句柄。
valueName:要设置的项值名称。
reserved:保留,可以设为0。
type:项值的类型。
value:所要设置的值。
对于RegSetValue,其参数的含义如下。
key:已经打开的项的句柄。
subKey:所要设置的子项。
type:项值的类型,必须为win32con.REG_SZ。
value:项值数据,为字符串。
以下的实例实现修改“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”的默认值,以及其“Version”项值数据。
# 将“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函数。RegDeleteKey函数可以删除注册表中的项。其参数原型分别如下所示。
RegCreateKey(key, subKey )
RegDeleteKey (key, subKey )
其参数含义相同,参数含义分别如下。
key:已经打开的注册表项的句柄。
subKey:所要操作(添加或删除)的子项。
以下的实例实现对“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项的添加、删除子项操作。
# 向“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”添加子项“Python”
>>> win32api.RegCreateKey(key,'Python')
# 新创建的子项的句柄
# 删除刚才创建的子项“Python”
>>> win32api.RegDeleteKey(key,'Python')
分享到:
相关推荐
本代码用于对电脑的注册表进行操作; 安装Python的Scrapy库时若碰到Python version2.7 required,which was not found in the register
Python操作注册表步骤之1.打开注册表 对注册表进行操作前,必须打开注册表。在Python中,可以使用以下两个函数:RegOpenKey和RegOpenKeyEx。其函数原型分别如下所示。 RegOpenKey(key, subKey , reserved , sam)...
使用python操作注册表的方法最近学习了一下,现在做一下笔记,由于对Python语言的使用还不是很熟练,所以写不出高大上的结构,但是解决问题搓搓有余了。 说道注册表顺便也说一说环境变量的修改(放下下一节讲),...
有时出于某种需要,希望用Python对注册表进行查找,创建,删除等操作。 本例演示了如何用Python删除注册表键值,并用另一个小程序演示如何注册该程序到注册表中,使其每次开机都会执行: RemoveValue.py: 删除指定...
主要介绍了python修改注册表终止360进程实例,是非常实用的进程操作技巧,需要的朋友可以参考下
不过这里介绍的是使用_winreg操作注册表,毕竟是Python自带的标准库,无需安装第三方库。 下面的例子是通过Python获取Windows XP下已经安装的补丁号。Windows的补丁号都在“HKEY_LOCAL_MACHINE\SOFTWARE\\Microsoft\...
通过python操作注册表主要有两种方式,一种是通过python的内置模块 _winreg,另一种方式就是 Win32 Extension For Python的win32api模块。这里主要简单看看用内置模块 _winreg如何操作注册表。 1.读取 读取用的方法...
通过Python操作注册表有两种方式,第一种是通过Python的内置模块 _winreg;另一种方式就是Win32 Extension For Python 的win32api模块,但是需要进行额外的安装。这里主要给出一些_winreg和win32api的Demo代码。 ...
主要介绍了Python实现修改IE注册表功能,结合完整实例形式分析了Python操作IE注册表项的相关实现技巧与注意事项,需要的朋友可以参考下
主要介绍了Python实现操纵控制windows注册表的方法,结合实例形式分析了Python使用_winreg模块以及win32api模块针对Windows注册表操作相关实现技巧,需要的朋友可以参考下
本文实例讲述了python关闭windows进程的方法。分享给大家供大家参考。... 您可能感兴趣的文章:操作Windows注册表的简单的Python程序制作教程Python实现修改IE注册表功能示例python修改注册表终止360进程实例pytho
usbdeviceforensics, 用于从 Windows 注册表中提取USB信息的python 脚本 简介usbdeviceforensics是一个 python 脚本,用于提取关于USB设备的大量信息。 它最初使用来自san博客( Rob ) post的信息来检索操作系统特定...
但是使用pyinstaller打包成exe文件的历程却是非常坎坷,一改脚本或者导入一个新的库,打包就出现各种报错,各种问题,最后博主实在找不到解决办法之后放弃了,谁知突然间却看到有博客说能直接把py程序设成开机自启,...
我又不想直接操作注册表 第二:命令行模式输入的字串长度有限制,这个是我调试好poython代码之后发现的,这个坑很大。 第三:windows cmd 中if下的两个字串的比较有时候不好使,跳过验证。 第四:命令行存在编码的...
python基础系列教程—Python3.x标准模块库目录 文本 1.string:通用字符串操作 2.re:正则表达式操作 3.difflib:差异计算工具 4.textwrap:文本填充 5.unicodedata:Unicode字符数据库 6.stringprep:互联网字符串...
问题描述: 1.当你卸载python库的时候,如:pip ...好了,第一步完成下面开始常规操作的两步: 第二步: 赋予用户对python的“完全控制”的权限,步骤如下: 找到按照python的位置,本文用的是Anaconda,安装在