用Python获取Windows本机安装的所有应用程序的实现与分析

一个项目中需要获取本机安装的所有应用程序列表,花了一点时间研究了一下,分享出来。

主要通过访问注册表和桌面快捷方式来完成这一任务,因为注册表中获取到的应用程序列表不完全,因此通过桌面快捷方式进行补充。

导入所需模块
python 复制代码
import winreg
import win32com.client
from pathlib import Path
  • winreg:用于访问Windows注册表。
  • win32com.client:用于处理Windows快捷方式。
  • Path:用于处理文件和目录路径。
通过注册表获取安装的应用程序
python 复制代码
def get_installed_apps_from_registry():
    """
    通过注册表查询安装的应用
    """
    apps = {}
    try:
        # 定义要查询的注册表路径
        reg_paths = [
            r"SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall",
            r"SOFTWARE\\WOW6432NODE\\Microsoft\\Windows\\CurrentVersion\\Uninstall"
        ]

        # 遍历所有注册表路径
        for reg_path in reg_paths:
            with winreg.OpenKey(winreg.HKEY_LOCAL_MACHINE, reg_path) as key:
                for i in range(winreg.QueryInfoKey(key)[0]):
                    sub_key_name = winreg.EnumKey(key, i)
                    with winreg.OpenKey(key, sub_key_name) as sub_key:
                        try:
                            app_name = winreg.QueryValueEx(sub_key, "DisplayName")[0]
                            # 排除驱动程序
                            if "驱动程序" in app_name:
                                continue
                            app_path = winreg.QueryValueEx(sub_key, "DisplayIcon")[0]
                            # 对 exe 路径进行过滤和清洗
                            if "exe" in app_path:
                                app_path = app_path.replace('"', '')
                                # 有一些 exe 文件的路径是以逗号分隔的,只取第一个
                                app_path = app_path.split(",")[0]
                                apps[app_name] = {"path": app_path}
                        except FileNotFoundError:
                            pass
    except Exception as e:
        print(f"Error: {e}")
    return apps

此函数执行以下操作:

  1. 定义注册表中存储已安装应用程序信息的路径。
  2. 遍历这些路径,并获取每个应用程序的名称和可执行文件路径。
  3. 过滤掉包含"驱动程序"的应用名称,清洗路径信息,构建应用程序字典。
获取桌面上的快捷方式
python 复制代码
def get_shortcuts_on_desktop():
    """
    查询桌面上安装的应用程序快捷方式
    """
    desktop_path = Path.home() / "Desktop"
    shortcuts = {}
    for item in desktop_path.iterdir():
        if item.suffix == ".lnk":
            shortcut_name = item.stem
            shortcuts[shortcut_name] = {"path": item}
    return shortcuts

此函数执行以下操作:

  1. 获取桌面目录路径。
  2. 遍历桌面上的所有文件,筛选出扩展名为.lnk(快捷方式)的文件,并保存其路径和名称。
根据快捷方式获取目标路径
python 复制代码
def get_target_path_by_shortcut(shortcut_path):
    """
    根据快捷方式获取应用程序的可执行文件(exe)路径
    :param shortcut_path: 快捷方式路径
    :return: 可执行文件(exe)路径
    """
    shell = win32com.client.Dispatch("WScript.Shell")
    shortcut = shell.CreateShortcut(shortcut_path)
    target_path = shortcut.TargetPath
    return target_path

此函数执行以下操作:

  1. 使用win32com.client模块来解析快捷方式。
  2. 获取快捷方式所指向的目标路径,即应用程序的可执行文件路径。
合并注册表和桌面快捷方式的信息
python 复制代码
def get_installed_apps_dict():
    """
    获取本机安装的所有应用程序
    :return: 安装的应用程序字典
    """
    installed_apps = get_installed_apps_from_registry()
    desktop_shortcuts = get_shortcuts_on_desktop()
    merged_apps = {}

    # 合并安装的应用程序和桌面快捷方式
    for app_name, app_info in installed_apps.items():
        merged_apps[app_name] = {"path": app_info["path"]}

    # 添加在桌面快捷方式中存在但未在安装应用程序中列出的软件
    for app_name, shortcut_info in desktop_shortcuts.items():
        if app_name not in installed_apps:
            shortcut_path = str(shortcut_info["path"])
            merged_apps[app_name] = {"path": get_target_path_by_shortcut(shortcut_path)}

    return merged_apps

此函数执行以下操作:

  1. 获取注册表中安装的应用程序和桌面上的快捷方式。
  2. 合并这两部分信息,确保所有应用程序都包含在结果中。
  3. 如果一个应用程序在桌面快捷方式中存在但未在注册表中列出,则从快捷方式获取其路径。
主程序入口
python 复制代码
if __name__ == '__main__':
    app_list = get_installed_apps_dict()
    for name, info in app_list.items():
        print(f"App Name: {name}")
        print(f"Executable Path: {info['path']}")
        print()
    print(f"Total Apps: {len(app_list)}")

主程序入口执行以下操作:

  1. 获取所有安装的应用程序列表。
  2. 打印每个应用程序的名称和路径。
  3. 输出总的应用程序数量。

通过这些步骤,该脚本能够有效地获取并列出Windows系统中安装的所有应用程序。

相关推荐
天天学IT几秒前
第三章 Qt 编译及安装
开发语言·qt·qt教程·qt6教程
xyq20241 分钟前
Window Memcached 安装指南
开发语言
IT小哥哥呀3 分钟前
基于windows的个人/团队的时间管理工具
windows·c#·wpf·时间管理
牛十二3 分钟前
openclaw安装mcporter搜索小红书
开发语言·javascript·ecmascript
老刘说AI5 分钟前
WorkFlow Agent案例:auto_document_agent(文件自动处理)
开发语言·数据库·人工智能·python·神经网络·自然语言处理
ZhengEnCi13 分钟前
M1-如何转换为HTML
python·html
时寒的笔记17 分钟前
js逆向05_ob混淆花指令,平坦流,某麦网(突破ob混淆寻找拦截器)
开发语言·前端·javascript
科学创新前沿20 分钟前
逆向设计新范式:深度学习驱动的声学超材料智能优化!
人工智能·python·深度学习·声学·逆向设计·声学超材料
咸鱼2.020 分钟前
【java入门到放弃】杂记
java·开发语言
Sagittarius_A*38 分钟前
传统图像分割:阈值 / 区域生长 / 分水岭 / 图割全解析【计算机视觉】
图像处理·人工智能·python·opencv·计算机视觉·图像分割