用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系统中安装的所有应用程序。

相关推荐
9***P3344 分钟前
Rust在网络中的Rocket
开发语言·后端·rust
u***457517 分钟前
Node.JS 版本管理工具 Fnm 安装及配置(Windows)
windows·node.js
大迪吃小迪22 分钟前
每秒 400 请求场景下,线程池如何合理配置?
java·开发语言
Wzx19801237 分钟前
go聊天室
开发语言·后端·golang
子午1 小时前
【蘑菇识别系统】Python+TensorFlow+Vue3+Django+人工智能+深度学习+卷积网络+resnet50算法
人工智能·python·深度学习
Mr_Xuhhh1 小时前
pytest -- 指定⽤例执⾏顺序
开发语言·python·pytest
tokepson1 小时前
关于python更换永久镜像源
python·技术·记录
F_D_Z1 小时前
【解决办法】网络训练报错AttributeError: module ‘jax.core‘ has no attribute ‘Shape‘.
开发语言·python·jax
chenyuhao20241 小时前
MySQL索引特性
开发语言·数据库·c++·后端·mysql
前端伪大叔1 小时前
第29篇:99% 的量化新手死在挂单上:Freqtrade 隐藏技能揭秘
后端·python·github