如何将Python打包后的exe还原成.py?

点击上方码农的后花园”,选择星标” 公众号

精选文章,第一时间送达

用到的工具

  1. pyinstxtractor.py 拆包(解压)工具,将exe文件解压成一个文件夹

  2. uncompyle6 pyc反编译工具

  3. 010EditorEditor 或者其他二进制查看与修改工具,我这里用的010Editor

安装方法

pip install uncompyle6
第一步:解包
python3 pyinstxtractor.py ***.exe   #  这里替换成你要反编译的exe文件

#  会生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据
2aab8d06a2e118a365475cdc359eb538.png
第二步:添加头信息

PyInstaller打包后,pyc文件的前8个字节会被抹掉,所以最后要自己添加回去。前四个字节为python编译的版本,后四个字节为时间戳。想要获得编译版本可以查看打包文件里struct的信息

1). 进入文件夹,找到以exe文件名命名的文件(没有后缀),这个就是目的文件5918b86d5ed1d977c701b73edb24f3f3.png

2). 用 010Editor 打开 struct,前八位就是我们想要的信息,将其复制

c166696c815c640a0a8ded9b9b423393.png

3). 用 010Editor 打开目的文件我这里是 abc_text,将上一步复制的信息插入到开头

修改前:

5da2a6e81117cd9c8c4c212e49120cb8.png

修改后:

240e914b568538134961a4b090743c6a.png

4). 将目的文件我这里是 abc_text,添加pyc的后缀

第三步:逆向目的文件.pyc

1). 其实这里已经可以使用了。了解python的都知道pyc是py文件编译后的二进制文件,因此如果想要分析源码还得继续逆向成.py文件cc8fced015cf9035a3306544ea808150.png

2). uncompyle6逆向pyc文件

uncompyle6 abc_text.pyc > abc_text.py
e9f372960e7a69c44e52fe74637a73dd.png


c6286c4ba904c36a3b0d1fb6398f90fe.png

eabdf08d0e76edf3827bc8ca69d0d7e3.png

来源:https://www.jianshu.com/p/5871c3dd633b

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值