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

用 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 SystemCare、IObit、Revo Uninstaller Pro(非免费版)、AVG Secure Browser等,需维护白名单/黑名单UninstallString或QuietUninstallString:存在且非空,才说明支持静默卸载;若只有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,按DisplayName或ImagePath过滤关键词 - 开机启动:扫描
Run、RunOnce键(SOFTWARE\Microsoft\Windows\CurrentVersion下),以及WOW6432Node对应路径 - 计划任务:用
schtasks /query /fo LIST /v输出后解析,或用win32com.client.Dispatch('Schedule.Service')接口 - 关键点:这些清理操作必须在主程序卸载**之后**执行,且服务需先
sc stop再sc delete,顺序错会导致删除失败
最易忽略的是:某些软件把自身更新服务注册为“延迟启动”,脚本执行时服务尚未加载,sc query 查不到——得强制枚举所有服务项并匹配名称。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
177 收藏
-
445 收藏
-
359 收藏
-
416 收藏
-
390 收藏
-
264 收藏
-
251 收藏
-
488 收藏
-
163 收藏
-
332 收藏
-
161 收藏
-
347 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习