A Python library for memory dumping
Project description
PyMemDump - Python 内存转储工具
PyMemDump 是一个用于转储系统进程内存的工具。它支持按进程名或PID指定目标进程,并将内存内容导出到指定的文件中。该工具还支持并发导出、指定地址范围导出、多种内容格式化选项等功能。
功能特点
- 多语言支持:支持英文(
en_US)和中文(zh_CN)。 - 灵活的目标进程指定:可以通过进程名或PID指定目标进程。
- 并发导出:支持多线程并发导出,提高导出效率。
- 指定地址范围导出:可以指定内存地址范围进行导出。
- 多种内容格式:支持
hex、bin、ascii等多种内容格式。 - 详细的日志记录:提供详细的日志信息,方便调试和问题追踪。
安装
通过pip安装
pip install PyMemDump
从源代码安装
-
克隆仓库:
git clone https://github.com/Fuxuan-CN/PyMemDump.git
-
进入目录并安装依赖:
cd PyMemDump pip install -r requirements.txt
使用方法
命令行接口
PyMemDump 提供了命令行接口,用户可以通过命令行参数灵活配置导出选项。以下是一些常用的命令行参数:
python -m PyMemDump --help
示例
-
全内存导出:
python -m PyMemDump --process notepad.exe --output ./dumps
-
并发导出:
python -m PyMemDump --process notepad.exe --output ./dumps --concurrent --workers 4
-
指定地址范围导出:
python -m PyMemDump --process notepad.exe --output ./dumps --by_addr --start-address 0x10000000 --end-address 0x10010000
-
扫描内存地址并保存到JSON文件:
python -m PyMemDump --process notepad.exe --scan_addr
Python接口
你也可以通过Python代码直接使用PyMemDump的功能:
from PyMemDump import MemoryDumper
dumper = MemoryDumper(process_desc="notepad.exe", save_path="./dumps")
dumper.dump()
国际化支持
- PyMemDump支持多语言,你可以如下操作切换语言:
from PyMemDump import MemoryDumper
MemoryDumper.dump_with_args(language="zh_CN")
- 不过一般来说,这个会自动检测语言来输出相应的提示信息。
python -m PyMemDump --help
目前支持的语言有:
-
英文(
en_US) -
中文(
zh_CN) -
法语 (
fr_FR) -
想帮忙添加语言?
查看下列文档来帮助你如何添加新语言;
日志记录
PyMemDump 提供了详细的日志记录功能,帮助用户跟踪内存导出过程中的问题。日志信息会显示在控制台,并且可以通过配置文件保存到文件中。
注意事项
- 确保目标进程正在运行,否则会报错。
- 确保输出目录存在且可写。
- 在某些操作系统或环境中,可能需要管理员权限才能访问某些进程的内存。
贡献
欢迎贡献代码或报告问题!你可以通过以下方式参与:
- 提交Pull Request
- 提交Issue
- 编写lang.json文件翻译
许可证
PyMemDump 采用 MIT 许可证,详情请参阅 LICENSE 文件。
联系方式
- GitHub: Fuxuan-CN
- Email:
fuxuan001@foxmail.com - QQ: 3072252442
- WeChat: Ricky-zhang1018
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pymemdump-0.2.1.post4.tar.gz.
File metadata
- Download URL: pymemdump-0.2.1.post4.tar.gz
- Upload date:
- Size: 25.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a7055bd93e1a249fe7cf3c1529c755a26557139d67bb7bd00ae82a66c1b81732
|
|
| MD5 |
dcefa2e21ef99ad776c8ad47c4d6d3b2
|
|
| BLAKE2b-256 |
0104c72b833ef9c18ebfd479f1410ad3c95b21faf7d093facb70a928ebe38742
|
File details
Details for the file PyMemDump-0.2.1.post4-py3-none-any.whl.
File metadata
- Download URL: PyMemDump-0.2.1.post4-py3-none-any.whl
- Upload date:
- Size: 30.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f33530b3de57729030d863a823cd27bbd82451ddac90d4e04de4f6030e34a58
|
|
| MD5 |
3b151331576b9d2345284308895b9d47
|
|
| BLAKE2b-256 |
7a418eede03d1071b697c516994971b8a2bcf4b7416339b4ddb3777fdb147d22
|