关于python获取当前用户名下的桌面或者document文件夹的方法

HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders

注册表

其实思想就是,通过注册表去获取。当前用户的desktop的注册表位置

HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders

import win32api,win32con   
def get_desktop():
        key = win32api.RegOpenKey(win32con.HKEY_CURRENT_USER,\
                              r'Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders',\
                              0,win32con.KEY_READ)
        print win32api.RegQueryValueEx(key,'Personal')[0]
        return win32api.RegQueryValueEx(key,'Desktop')[0]

1.打开注册表
对注册表进行操作前,必须打开注册表。在Python中,可以使用以下两个函数:RegOpenKey和RegOpenKeyEx。其函数原型分别如下所示。

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等。

2.关闭注册表
打开的注册表,在操作完成后,需要关闭。在Python中使用RegCloseKey函数关闭打开的注册表项。其函数原型如下所示。
RegCloseKey(key)
其参数只有一个,其含义如下。

key:已经打开的注册表项。

以下实例关闭一个已经打开的注册表项。

win32api.RegCloseKey(key)  
print key  

3.读取项值
在打开注册表项以后,可以使用RegQueryValue函数读取项的默认值。如果要读取某一项值,可以使用RegQueryValueEx函数。其函数原型分别如下所示。

RegQueryValue(key, subKey )  
RegQueryValueEx(key, valueName )  

对于RegQueryValue,其参数含义如下。

key:已打开的注册表项的句柄。
subKey:要操作的子项。

对于RegQueryValueEx,其参数含义如下。

key:已经打开的注册表项的句柄。
valueName:要读取的项值名称。

def get_currentuser_documents():
    # 打开“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项  
    key = win32api.RegOpenKey(win32con.HKEY_LOCAL_MACHINE,  
    'SOFTWARE\\Microsoft\\Internet Explorer',0, win32con.KEY_ALL_ACCESS)  
    print win32api.RegQueryValue(key, '') # 读取项的默认值  
    #读取项值名称为Version的项值数据,也就是Internet Explorer的版本  
    print win32api.RegQueryValueEx(key,'Version')

4.设置项值
要修改或者重新设置注册表某一项的项值可以使用RegSetValueEx函数,如果要设置项的默认值可以使用RegSetValue函数。需要说明的是,对于RegSetValueEx,如果要设置的项值不存在,那么RegSetValueEx会添加该项值,如果存在,则修改该项值。其函数原型分别如下所示。

RegSetValueEx(key, valueName, reserved, type, value)  
RegSetValue(key, subKey, type, value)  

对于RegSetValueEx,其参数含义如下。

key:要设置的项的句柄。
valueName:要设置的项值名称。
reserved:保留,可以设为0。
type:项值的类型。
value:所要设置的值。

对于RegSetValue,其参数的含义如下。

key:已经打开的项的句柄。
subKey:所要设置的子项。
type:项值的类型,必须为win32con.REG_SZ。
value:项值数据,为字符串。

以下的实例实现修改“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”的默认值,以及其“Version”项值数据。

# 将“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函数。RegDeleteKey函数可以删除注册表中的项。其参数原型分别如下所示。

RegCreateKey(key, subKey )  
RegDeleteKey (key, subKey )  

其参数含义相同,参数含义分别如下。

key:已经打开的注册表项的句柄。
subKey:所要操作(添加或删除)的子项。

以下的实例实现对“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项的添加、删除子项操作。

# 向“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”添加子项“Python”  
win32api.RegCreateKey(key,'Python')  
  # 新创建的子项的句柄  
# 删除刚才创建的子项“Python”  
win32api.RegDeleteKey(key,'Python')  

总体的代码

def get_currentuser_documents():
    # 打开“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer”项  
    key = win32api.RegOpenKey(win32con.HKEY_LOCAL_MACHINE,  
    'SOFTWARE\\Microsoft\\Internet Explorer',0, win32con.KEY_ALL_ACCESS)  
    print key
    print win32api.RegQueryValue(key, '') # 读取项的默认值  
    #读取项值名称为Version的项值数据,也就是Internet Explorer的版本  
    print win32api.RegQueryValueEx(key,'Version')    

    print win32api.RegQueryInfoKey(key)  # RegQueryInfoKey函数查询项的基本信息
    #win32api.RegCreateKey(key,'Pythonqw')  #HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Internet Explorer\Pythonqw
    # win32api.RegSetValue(key,'',win32con.REG_SZ,'pythonqw')
    # # 将其“Version”设置为7.0.2900.2180  
    # win32api.RegSetValueEx(key,'Version',0,win32con.REG_SZ,'7.0.2900.2180')
    # win32api.RegDeleteKey(key,'Pythonqw')  

ps获取当前操作系统用户名的方法-windows与linux均可行

import getpass
getpass.getuser()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 今年开始做C++服务器开发了,所以来记录下自己用到的东西。分析Core Dump文件一般好像都是用windbg、d...
    那些云阅读 28,842评论 2 7
  • Windows用户文件夹中存放着许多诡异而重要的文件和配置等,许多文件的路径也与其用户文件的命名有关。因此,如果将...
    机灵鬼机灵阅读 8,001评论 0 0
  • 1. 中断命令执行 Ctrl + Z 2. 文件/目录 cd 切换目录 例:cd // 显示当前目录 例:...
    皓皓amous阅读 4,110评论 0 0
  • 0 操作成功完成。1 功能错误。2 系统找不到指定的文件。3 系统找不到指定的路径。4 系统无法打开文件...
    ccq_inori阅读 7,998评论 0 0
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 12,204评论 16 22

友情链接更多精彩内容