当前位置: 移动技术网 > IT编程>脚本编程>Python > Python实现操纵控制windows注册表的方法分析

Python实现操纵控制windows注册表的方法分析

2019年06月02日  | 移动技术网IT编程  | 我要评论

窗帘布,ajviewer,8人殴辱17岁少女

本文实例讲述了python实现操纵控制windows注册表的方法。分享给大家供大家参考,具体如下:

使用_winreg模块的话

基本概念:

  • key 键
  • value 值

函数和作用:

closekey() - 关闭一个key
connectregistry() - 链接到其他机器的注册表
createkey() - 创建一个key
deletekey() - 删除一个key
deletevalue() - 删除一个key里面的值(value)
enumkey() - 为已经打开的key里面的子键建立索引
enumvalue() - 为打开的键中的值建立索引
flushkey() - 回写所有的键属性改变到注册表
loadkey() - 从指定文件读入键信息
openkey() - 打开一个键
openkeyex()
queryvalue() - 在注册表中检索一个键的路径
queryvalueex() - 注册表中检索一个键的路径
queryinfokey() - 返回关于键的信息
savekey() - 保存键到文件
setvalue() - 设置一个键
setvalueex() - 设置一个值

1、读取

import _winreg
key = _winreg.openkey(_winreg.hkey_current_user,r"software\microsoft\windows\currentversion\explorer")
 #获取该键的所有键值,因为没有方法可以获取键值的个数,所以只能用这种方法进行遍历
 try:
  i = 0
while1:
#enumvalue方法用来枚举键值,enumkey用来枚举子键
     name, value, type = _winreg.enumvalue(key, i)
print repr(name),
    i +=1
 except windowserror:
print
 #如果知道键的名称,也可以直接取值
 value, type = _winreg.queryvalueex(key, "enableautotray")

2 、创建、修改

import _winreg
key = _winreg.openkey(_winreg.hkey_current_user,r"software\microsoft\windows\currentversion\explorer")
#删除键
_winreg.deletekey(key, "advanced")
#删除键值
_winreg.deletevalue(key, "iconunderline")
#创建新的键
newkey = _winreg.createkey(key,"mynewkey")
#给新创建的键添加键值
_winreg.setvalue(newkey,"valuename",0,"valuecontent")

3、 访问远程注册表

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

4、win32api

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

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

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

import _winreg
key = _winreg.openkey(_winreg.hkey_local_machine,r"software\microsoft\windows")
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提供的方法来修改上面的代码如下:

import win32api
import win32con
key = win32api.regcreatekeyex(win32con.hkey_local_machine, r"software\microsoft\windows", win32con.write_owner |win32con.key_wow64_64key|win32con.key_all_access)
win32api.regsetvalueex (key,"mynewkey", 0, win32con.reg_sz, keyvalue)

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

更多关于python相关内容感兴趣的读者可查看本站专题:《python文件与目录操作技巧汇总》、《python文本文件操作技巧汇总》、《python数据结构与算法教程》、《python函数使用技巧总结》、《python字符串操作技巧汇总》及《python入门与进阶经典教程

希望本文所述对大家python程序设计有所帮助。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网