眼观千遍 → 耳听万遍 → 不如手动一遍√

  :: :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
通过Python操作注册表有两种方式,第一种是通过Python的内置模块 _winreg;另一种方式就是Win32 Extension For Python 的win32api模块,但是需要进行额外的安装。这里主要给出一些_winreg和win32api的Demo代码。
 
1、 _winrg
可以参考官方的参考文档:
http://docs.python.org/library/_winreg.html
http://www.python.org/doc/2.6.2/library/_winreg.html
 
1.1 读取 
 
1 import _winreg
2
3 key = _winreg.OpenKey(_winreg.HKEY_CURRENT_USER,r"Software\Microsoft\Windows\CurrentVersion\Explorer")
4
5  #获取该键的所有键值,因为没有方法可以获取键值的个数,所以只能用这种方法进行遍历
6  try:
7 i = 0
8 while1:
9 #EnumValue方法用来枚举键值,EnumKey用来枚举子键
10   name, value, type = _winreg.EnumValue(key, i)
11 print repr(name),
12 i +=1
13  except WindowsError:
14 print
15
16  #如果知道键的名称,也可以直接取值
17  value, type = _winreg.QueryValueEx(key, "EnableAutoTray")

 

1.2 创建、修改

 

1 import _winreg
2
3 key = _winreg.OpenKey(_winreg.HKEY_CURRENT_USER,r"Software\Microsoft\Windows\CurrentVersion\Explorer")
4
5 #删除键
6 _winreg.DeleteKey(key, "Advanced")
7
8 #删除键值
9 _winreg.DeleteValue(key, "IconUnderline")
10
11 #创建新的键
12 newKey = _winreg.CreateKey(key,"MyNewkey")
13
14 #给新创建的键添加键值
15 _winreg.SetValue(newKey,"ValueName",0,"ValueContent")

 

1.3 访问远程注册表

 

1 #第二参数必须是HKEY_CURRENT_USER、HKEY_LOCAL_MACHINE等预先定义好的值,拿到返回的key后就可以进行操作了
2 key = _winreg.ConnectRegisty("IP地址或者机器名",_winreg.HKEY_CURRENT_USER)

 

 

2、 win32api

win32api 和 _winreg 的方法很类似,一般是多了一个前缀"Reg",使用方法很基本上一样,这里就不给具体的Demo代码了。

就一般的应用来说,使用_winreg就足够了,但是_winreg有一个问题,如果Python是32位的,并且是运行在64位的操作系统上时就会有一点小问题,由于操作系统会进行注册表的重定向,32位的程序无法访问64位应用程序的注册表。在Python2.6以前这个问题都没有解决,在Python2.7中通过补丁的形式修正了这个问题(http://bugs.python.org/issue7347)。

通过例子来说明一下这个问题,假设我们的操作系统是64位的,然后在上面安装了32位的Python,看如下的Python代码:

 

1 import _winreg
2
3 key = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE,r"Software\Microsoft\Windows")
4
5 newKey = _winreg.CreateKey(key,"MyNewkey")

 

上面的代码的执行不会像预想那样创建如下的键:

"HKEY_LOCAL_MACHINE\Software\Microsoft\Windows"

而是会创建如下的键:

"HKEY_LOCAL_MACHINE\Software\Wow6432Node\Microsoft\Windows"

因为在64位的windows操作系统下,64位的程序和32位程序的注册表是分开的,32位应用程序对注册表的操作(读、写)都会被重定向到Wow6432Node下面, 64位应用程序的访问注册表的行为则没有变化。因此如果我们的32位应用程序确实要访问64位程序所用到的注册表的话,就会有点问题。由于_winreg本身的问题,它对这种情况的支持不太充分,对windows api的封装有一些bug,这个时候就需要用到 win32api 模块。

下面用win32api提供的方法来修改上面的代码如下:

 

1 import win32api
2
3 import win32con
4
5 key = win32api.RegCreateKeyEx(win32con.HKEY_LOCAL_MACHINE, r"Software\Microsoft\Windows", win32con.WRITE_OWNER |win32con.KEY_WOW64_64KEY|win32con.KEY_ALL_ACCESS)
6 win32api.RegSetValueEx (key,"MyNewkey", 0, win32con.REG_SZ, keyValue)

 

上面的win32con.KEY_WOW64_64KEY意思就是直接访问64位注册表,不要进行重定向,默认的参数是win32con.KEY_WOW64_32KEY。

 

posted on 2010-01-04 18:11  无恙  阅读(29584)  评论(0编辑  收藏  举报