Python 批量分析windows程序崩溃捕获的dump文件

使用Python脚本结合CDB和pdb文件,对windows程序的dump文件进行批量分析,通过读取pdb路径,运行cdb命令获取崩溃堆栈信息,并将结果整理输出到单独文本文件中。
摘要由CSDN通过智能技术生成

dump文件可以用CDB和编译生成的pdb文件获取出崩溃堆栈,定位崩溃代码段。
在pdbPath.txt中读取pdb文件的路径。
用python运行cdb 带参数命令,逐个解析dump 文件,将解析结果保存到对于名字的文本文件内,再从这些文件中摘取堆栈信息输出到文本。

# -*- coding: gbk -*-
import os
import os.path
import sys
import zipfile
import subprocess

def we_are_frozen():
# All of the modules are built-in to the interpreter, e.g., by py2exe
    return hasattr(sys, "frozen")

def module_path():
    encoding = sys.getfilesystemencoding()
    if we_are_frozen():
        return os.path.dirname(sys.executable.encode(encoding))
    return os.path.dirname(os.path.abspath(__file__.encode(encoding)))

def files_in_path(path):
    <
Windows程序崩溃时,操作系统会生成一个崩溃转储(Dump文件,用于帮助开发人员诊断和调试程序故障。这个Dump文件记录了程序崩溃时的内存状态,包括堆栈信息、寄存器状态、变量值等关键数据。 生成Dump文件的方法有多种,例如: 1. 使用Windows上自带的任务管理器。打开任务管理器,在“进程”选项卡中找到崩溃程序进程,右键点击选择“创建转储文件”即可生成Dump文件。 2. 使用Windows上自带的Dr.Watson工具(仅适用于旧版本)。Dr.Watson是一种活动监视工具,它会在程序崩溃时自动记录信息,生成.DMP文件。可以在Windows注册表中启用Dr.Watson功能。 3. 使用Windows Debugging Tools。这是一套由微软提供的调试工具,其中包括了生成Dump文件的命令行工具Dumpchk、Msdia.dll等。使用这些工具可以对Dump文件进行详细的调试和分析。 一旦生成了Dump文件,开发人员可以使用各种调试工具来分析这个文件,以寻找程序崩溃的原因。比如,可以使用Visual Studio自带的调试器或WinDbg调试器来打开Dump文件,并逐步调试程序,查看导致崩溃的代码行。 Dump文件对于故障排除非常有用,可以帮助开发人员定位和解决程序中的错误。通过分析Dump文件,我们可以获得崩溃时的内存状态,从而找到导致崩溃的具体代码,修复问题,提升软件的稳定性和可靠性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值