㈠ python 修改注册表只能是REG_SZ吗 我想修改二进制但是报错说只能是REG_SZ
方法一:利用regedit/s命令在启动项里,添加后门。@.00>run.regecho[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run]>>run.regecho"Door"=C:\\WINNT\\system32\\door.exe>>run.regregedit/srun.reg顺便再讲一下如何删除注册表对应位置:用""来清除键值用-来删除项删除子项:WindowsRegistryEditorVersion5.00[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run]"door"=-执行该文件,[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run]下的"door"就被删除了;删除项:WindowsRegistryEditorVersion5.00[-HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run]执行该脚本,[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run]就已经被删除了。方法二:利用reg命令,添加、修改、删除注册表REGADD添加、修改REGDELETE删除相关参数到输入/h看帮助。例:REGADDHKLM\Software\MyCo/vMRU/tREG_MULTI_SZ/d%%systemroot%%添加一个值(名称:MRU,类型:REG_MUTLI_SZ,数据:%systemroot%)
㈡ Python代码来读取注册表问题,怎么解决
windows上的python有内置模块winreg用于操作注册表,其文档可以在 开始>所有程序>Python>Python Mole Docs中找到
㈢ 如何使用python修改注册表
1.
打开注册表
regopenkey(key,
subkey,
reserved,
sam)
regopenkeyex(key,
subkey,
reserved,
sam)
两个函数的参数一样。参数含义如下:
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
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
2.
关闭注册表
regclosekey(key)
其参数只有一个,其含义如下:
l
key:已经打开的注册表项的句柄。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
如win32api.regclosekey(key)
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
3.
读取项值
regqueryvalue(key,subkey)
读取项的默认值
regqueryvalueex(key,valuename)
读取某一项值
对于regqueryvalue,其参数含义如下:
l
key:已打开的注册表项的句柄。
l
subkey:要操作的子项。
对于regqueryvalueex,其参数含义如下:
l
key:已经打开的注册表项的句柄。
l
valuename:要读取的项值名称。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
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(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')
#
将其“version”设置为7.0.2900.2180
>>>
win32api.regsetvalueex(key,'version',0,win32con.reg_sz,'7.0.2900.2180')
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
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')
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
6.
错误处理
importerror:
no
mole
named
win32api出现异常
望采纳!
㈣ Python 读取注册表的问题,求助 · Ruby China
如果你打算做 python-china.org 的话,是商业目的还是公益目的呢?
如果是商业目的,那么这样带有强烈单独语言假设的网站,在发展的时候,恐怕会遇到限制。
而如果是公益目的,想帮助别的 Python 开发者,那么你需要问自己,你真的想做一个面向 Python 开发者的媒体吗?
㈤ python操作注册表的问题 win32api.RegSetValueEx(key,'Start Page',0,win32con.REG_SZ, page)
是GBK编码。拒绝访问
应该是你使用的用户没有权限修改注册表或者关于IE注册表被锁定了。
㈥ python 创建注册表
http://blog.sina.com.cn/s/blog_4b5039210100gmsb.html
winreg.SetValue(key, "MyNewKey", winreg.REG_SZ, "New")这句话应该改成
winreg.SetValue(newkey, "MyNewKey", winreg.REG_SZ, "New")给新建的键改值
㈦ python注册表信息在哪个文件夹
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#!/usr/bin/python3
# -*- coding: utf-8 -*-
import winreg
def show_software():
key = winreg.OpenKey(winreg.HKEY_CURRENT_USER, 'software', 0, winreg.KEY_READ)
result = []
index = 0
while True:
try:
name = winreg.EnumKey(key, index)
result.append(name)
index += 1
except OSError:
break
winreg.CloseKey(key)
print(result)
if __name__ == '__main__':
show_software()
㈧ 如何使用 Python 访问注册表
对注册表进行操作前,必须打开注册表。在Python中,可以使用以下两个函数:RegOpenKey和RegOpenKeyEx。其函数原型分别如下所示。
Html代码
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_USERSoftware”项。
㈨ 如何修改python自己的 注册表
修改python自己的 注册表
默认情况下,在windows下安装python之后,系统并不会自动添加相应的环境变量。此时不能在命令行直接使用python命令。
1. 首先需要在系统中注册python环境变量:假设python的安装路径为c:\python2.6,则修改我的电脑->属性->高级->环境变量->系统变量中的PATH为:
(为了在命令行模式下运行Python命令,需要将python.exe所在的目录附加到PATH这个环境变量中。)
PATH=PATH;c:\python26
上述环境变量设置成功之后,就可以在命令行直接使用python命令。或执行"python *.py"运行python脚本了。
2. 此时,还是只能通过"python *.py"运行python脚本,若希望直接运行*.py,只需再修改另一个环境变量PATHEXT:
PATHEXT=PATHEXT;.PY;.PYM
3. 另外,在使用python的过程中,可能需要经常查看某个命令的帮助文档,如使用help('print')查看print命令的使用说明。默认安装的python无法查看帮助文档,尚需进行简单的配置:
在python安装目录下,找到python25.chm,使用hh -decompile .python26.chm将其反编译出来,然后将其所在的目录加入到上面提到的PATH环境变量中即可。
4. 如何使Python解释器能直接import默认安装路径以外的第三方模块?
为了能import默认安装路径以外的第三方的模块(如自己写的模块),需要新建PYTHONPATH环境变量,值为这个模块所在的目录。
------------------------------------------------------------------------------------------------------
.... 在我的电脑上面右键-》属性-》系统设置-》高级-》下面有个环境变量的按钮,点开之后,在系统变量找到path,在最后或者最前面添加 PYTHON_HOME的路径。记不清了,现在没用win7,用的linux,。。。 ----------------------------------------------------------------------------
windows的话直接加到path下就行,python_home那个如果用django的话,需要弄,别的不用。 另外,我也推荐用linux
㈩ python里面的注册表怎么进去
在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)
下面内容转自 Python Standard Library12.13 The _winreg Mole
(Windows
only, New in 2.0) The _winreg mole provides a basic interface to the
Windows registry database. Example 12-17 demonstrates the mole.
Example 12-17. Using the _winreg Mole
File: winreg-example-1.py
复制代码 代码如下:
import _winreg
explorer = _winreg.OpenKey(
_winreg.HKEY_CURRENT_USER,
"Software\\Microsoft\\Windows\CurrentVersion\\Explorer"
)
#list values owned by this registry key
try:
i = 0
while 1:
name, value, type= _winreg.EnumValue(explorer, i)
print repr(name),
i += 1
except WindowsError:
print
value, type = _winreg.QueryValueEx(explorer, "Logon User Name")
print
print "user is", repr(value)
'Logon User Name' 'CleanShutdown' 'ShellState' 'Shutdown Setting'
'Reason Setting' 'FaultCount' 'FaultTime' 'IconUnderline'...
user is u'Effbot'