登录
首页 >  文章 >  python教程

Python批量卸载Windows流氓软件教程

时间:2026-05-23 09:11:14 390浏览 收藏

推广推荐
前往下载Windows工具 ➜
支持 PC / 移动端,安全直达
本文详解了在新版Windows系统中如何用Python安全、精准地批量卸载流氓软件,直击wmic弃用、PowerShell性能差等常见痛点,主张以管理员权限读取注册表Uninstall及Wow6432Node路径,结合Publisher、UninstallString和DisplayName三字段智能识别风险软件,规避误删系统组件;同时提供静默卸载的实战技巧(如命令安全解析、MSI提取ProductCode、绕过弹窗与反脚本检测),并强调卸载后必须清理残留服务、启动项和计划任务的完整闭环方案,是兼顾可靠性、兼容性与生产可用性的硬核实操指南。

如何用Python编写脚本批量自动化卸载Windows流氓软件

subprocess 调用 wmic 卸载时为什么没反应?

因为 wmic 在较新 Windows 版本(尤其是 22H2+)中默认已弃用,且多数“流氓软件”不注册标准 Win32_Product 类,wmic product get name,identifyingnumber 基本查不到它们。强行调用只会返回空或超时。

实操建议:

  • 优先改用 Get-WmiObject Win32_Product(PowerShell)——但性能极差,且会触发 MSI 自检,可能卡死或误修复其他软件;不推荐用于批量
  • 真正可靠的方式是查注册表:所有安装信息集中在 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall 及其 Wow6432Node 子键
  • 用 Python 读取注册表时,必须以管理员权限运行脚本,否则无法访问 HKEY_LOCAL_MACHINE
  • 注意 32/64 位软件注册位置不同:Uninstall 下是 64 位项,Wow6432Node\Uninstall 下是 32 位项

如何精准识别“流氓软件”而不是误删系统组件?

不能只靠软件名关键词(如含“PC”“Boost”就删),很多正规工具也带这类词。关键看三处注册表值:

  • DisplayName:用户看到的名称,可作初筛
  • Publisher:重点字段,常见流氓厂商如 Advanced SystemCareIObitRevo Uninstaller Pro(非免费版)、AVG Secure Browser 等,需维护白名单/黑名单
  • UninstallStringQuietUninstallString:存在且非空,才说明支持静默卸载;若只有 ModifyPath 或为空,大概率只能手动点卸载界面

示例判断逻辑(伪代码):

if 'IObit' in publisher and uninstall_string and 'msiexec' not in uninstall_string.lower():
    # 可能是 IObit 的自定义安装器,尝试加 /S 参数
    cmd = f'"{uninstall_string}" /S'

静默卸载失败的常见错误和绕过方法

直接执行 UninstallString 常见报错:"The system cannot find the file specified",本质是路径含空格未加引号,或调用了相对路径的子程序。

  • 先用 shlex.split() 安全解析命令字符串,再用 subprocess.run(..., shell=False) 执行
  • 若卸载程序是 MSI 包,优先提取 ProductCode(IdentifyingNumber 值),用 msiexec /x {XXXX} /qn 静默移除
  • 遇到弹窗式卸载器(如某些国产安全软件),pyautogui 不稳定也不推荐;更稳妥的是用 psutil 监控进程启动,再发 WM_CLOSE 消息,但需额外依赖 GUI 权限
  • 部分软件(如 360、腾讯电脑管家)会检测是否被脚本调用,静默参数无效——此时只能标记为“需人工确认”,写入日志并跳过

为什么卸载后残留服务/启动项/计划任务?

注册表卸载项只管主程序,但流氓软件常额外注册:

  • 服务:检查 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services,按 DisplayNameImagePath 过滤关键词
  • 开机启动:扫描 RunRunOnce 键(SOFTWARE\Microsoft\Windows\CurrentVersion 下),以及 WOW6432Node 对应路径
  • 计划任务:用 schtasks /query /fo LIST /v 输出后解析,或用 win32com.client.Dispatch('Schedule.Service') 接口
  • 关键点:这些清理操作必须在主程序卸载**之后**执行,且服务需先 sc stopsc delete,顺序错会导致删除失败

最易忽略的是:某些软件把自身更新服务注册为“延迟启动”,脚本执行时服务尚未加载,sc query 查不到——得强制枚举所有服务项并匹配名称。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>