与注册表操作相关的函数可以分为打开注册表、关闭注册表、读取项值、c添加项值、添加项,以及删除项等几类。

描述

HKEY_CLASSES_ROOT,是HKEY_LOCAL_MACHINE\Software 的子项,保存打开文件所对应的应用程序信息
HKEY_CURRENT_USER,是HKEY_USERS的子项,保存当前用户的配置信息
HKEY_LOCAL_MACHINE,保存计算机的配置信息,针对所有用户
HKEY_USERS,保存计算机上的所有以活动方式加载的用户配置文件
HKEY_CURRENT_CONFIG,保存计算机的硬件配置文件信息

通过使用win32api模块和win32con模块,python可以方便地访问注册表,并对其进行打开、关闭、添加项、删除项,以及添加、修改项值等操作。

1. 打开注册表

RegOpenKey(key,   subkey,   reserved,   sam)
RegOpenKeyEx(key, subkey, reserved, sam)
  • 1
  • 2

两个函数的参数一样。参数含义如下:
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

1

  • 2
  • 3
  • 4

.2. 关闭注册表

RegCloseKey(key)
  • 1

其参数只有一个,其含义如下:
l Key:已经打开的注册表项的句柄。

如win32api.RegCloseKey(key)
  • 1

.3. 读取项值
RegQueryValue(key,subKey) 读取项的默认值
RegQueryValueEx(key,valueName) 读取某一项值

对于RegQueryValue,其参数含义如下:
l Key:已打开的注册表项的句柄。
l subKey:要操作的子项。

对于RegQueryValueEx,其参数含义如下:
l Key:已经打开的注册表项的句柄。
l valueName:要读取的项值名称。

import win32api
import win32con
  • 1
  • 2

打开“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项

key = win32api.RegOpenKey(win32con.HKEY_LOCAL_MACHINE,
'SOFTWARE\\Microsoft\\Internet Explorer',0, win32con.KEY_ALL_ACCESS)
  • 1
  • 2

win32api.RegQueryValue(key,”) # 读取项的默认值
” # 输出为空,表示其默认值未设置

读取项值名称为Version的项值数据,也就是Internet Explorer的版本

win32api.RegQueryValueEx(key,'Version')  
  • 1

(‘6.0.2900.2180’, 1)

>>> win32api.RegQueryInfoKey(key)  # RegQueryInfoKey函数查询项的基本信息
  • 1

(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')
  • 1

将其“Version”设置为7.0.2900.2180

win32api.RegSetValueEx(key,'Version',0,win32con.REG_SZ,'7.0.2900.2180')
  • 1

.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')
  • 1
  • 2
  • 3
  • 4
  • 5

.6. 错误处理

ImportError: No module named win32api #出现异常
  • 1

实际是需要安装和自己python兼容的win32all(pywin32)
http://starship.python.net/crew/mhammond/downloads/ 可以下载适合自己的版本,安装;记住必须重启才可生效。

关于错误,你写错根本运行不起来,不用担心,返回值问题

python之操作注册表的更多相关文章

  1. python路径写入注册表,导入三方模块win32

    python在安装第三方模块时候,需要将python的路径写入注册表,否则会提示 'python version 3.8-32 required,which was not found in the ...

  2. [转]C#操作注册表

    原文链接:http://www.cnblogs.com/txw1958/archive/2012/08/01/csharp-regidit.html 下面我们就来用.NET下托管语言C#注册表操作,主 ...

  3. [荐]使用Js操作注册表

    使用Js操作注册表 要操作注册表需要通过ActiveX控件调用WScript.shell对象,通过该对象的一些方法来操作. WshShell对象:可以在本地运行程序.操纵注册表内容.创建快捷方式或访问 ...

  4. c++ 操作注册表

    1.       注册表简介 注册表是为Windows NT和Windows95中所有32位硬件/驱动和32位应用程序设计的数据文件,用于存储系统和应用程序的设置信息.16位驱动在Winnt (Win ...

  5. .Net操作注册表--un

    C#操作注册表 导入命名空间 Using MicroSoft.Win32;//64位系统装的64位版本

  6. C#操作注册表全攻略

    相信每个人对注册表并不陌生,在运行里面输入“regedit”就可以打开注册表编辑器了.这东西对Windows系统来说可是比较重要的,也是病 毒常常会光顾的地方,比如病毒和恶意软件常常会在注册表的启动项 ...

  7. C#获取cpu序列号 硬盘ID 网卡硬地址以及操作注册表 .

    转:http://blog.csdn.net/smartsmile2012/article/details/8682295 #region 获取cpu序列号 硬盘ID 网卡硬地址 /**/ /// & ...

  8. VBS 操作注册表 十六进制

    使用VBS操作注册表,通常使用RegRead/RegWrite/RegDelete方法,如: RegRead: 'read.vbs(将以下代码存为read.vbs文件) Dim OperationRe ...

  9. win7 64bit+vs2010 操作注册表

    注册表五个根键 HKEY_CLASSES_ROOT--管理文件系统  HKEY_LOCAL_MACHINE--管理当前系统硬件配置  HKEY_LOCAL_USER--管理系统当前用户配置  HKEY ...

  10. How to:Installshield判断操作系统是否为64位,并且为操作注册表进行设置

    原文:How to:Installshield判断操作系统是否为64位,并且为操作注册表进行设置 IS脚本操作注册表在64位平台下必须有特殊的设置 if (SYSINFO.bIsWow64) then ...

随机推荐

  1. homework2软件方法论

    什么是软件工程方法论? 1.软件工程是一个方法论,就是我们在开始一个项目时,大体框架一定要有这么一个概念,而具体实施时,必须根据公司一些特点,优化项目开发的流程,这样才是有实效而方法论只是软件工程的结 ...

  2. [postman的使用]postman捕获https请求

    解决方法: 1.settings 2.SSL certificate verifivation设置为关闭

  3. 下载Vue.js输入Vue -V报错解决办法

    报错如图所示 解决办法: 1. 以管理员身份运行vscode; 2. 执行:get-ExecutionPolicy,显示Restricted,表示状态是禁止的; 3. 执行:set-Execution ...

  4. down_interruptible()获取信号量

    信号量(Semaphore)是操作系统中最典型的用于同步和互斥的手段,信号量的值可以是0.1或者n.信号量与操作系统中的经典概念PV操作对应. P(S):①将信号量S的值减1,即S=S-1:②如果S≥ ...

  5. [Leetcode 235/236]LCA二叉树最近公共祖先Lowest Common Ancestor of a Binary Tree

    题目 给定二叉树和两个点,求两点的LCA最近公共祖先 Given a binary tree, find the lowest common ancestor (LCA) of two given n ...

  6. 记录一次MySQL主从同步

    主库配置 server-id=1log-bin=mysql-binbinlog_format=ROWbinlog_row_image=minimalbinlog-do-db=yjtb-cloud 解释 ...

  7. MySQL 导出单表数据

    1.导出指定表的数据 mysqldump -t database -u username -ppassword --tables table_name1 table_name2 table_name3 ...

  8. 登录:ORA-12504:TNS:监听程序在CONNECT_DATA中未获得SERVICE_NAME

    问题描述:在用pl/sql登录soctt用户时,显示: 解决办法:在tnsnames.ora文件中添加(文件位置的查找方法见文章末尾) ORCL = (DESCRIPTION = (ADDRESS = ...

  9. 手把手带你玩转Linux

    今天这篇文章带你走进Linux世界的同时,带你手把手玩转Linux,加深对Linux系统的认识. 一.搞好Linux工作必须得不断折腾,说白了,只是动手力量必须强.我在初学Linux的那片,家中三台计 ...

  10. Android笔记--Room增删改查

    添加 查询 删除 修改