QQ登录

只需要一步,快速开始

APP扫码登录

只需要一步,快速开始

查看: 7031|回复: 0

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

[复制链接]

等级头衔

积分成就    金币 : 2861
   泡泡 : 1516
   精华 : 6
   在线时间 : 1322 小时
   最后登录 : 2025-10-13

丰功伟绩

优秀达人突出贡献荣誉管理论坛元老活跃会员

联系方式
发表于 2021-12-2 10:25:03 | 显示全部楼层 |阅读模式
一、用到的工具
6 e  O# H& I% _& S1 Z; V
  • pyinstxtractor.py  拆包(解压)工具,将exe文件解压成一个文件夹
  • uncompyle6  pyc反编译工具
  • 010EditorEditor  或者其他二进制查看与修改工具,这里用的010Editor7 [$ o- ?( l6 M
二、安装方法
; Z) a6 _, [% M6 l
pip install uncompyle6
第一步:解包- C% m" ?+ z3 g8 s' |7 p1 n; p
python3 pyinstxtractor.py ***.exe   #  这里替换成你要反编译的exe文件2 \4 M# _' Z4 m% A( I4 R
#  会生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据
1.jpg % g( b9 A  I7 I3 N. e( J9 U
第二步:添加头信息- L: K! M  E9 f! F% J
       PyInstaller打包后,pyc文件的前8个字节会被抹掉,所以最后要自己添加回去。前四个字节为python编译的版本,后四个字节为时间戳。想要获得编译版本可以查看打包文件里struct的信息4 k; K$ c8 ?3 i$ @
1). 进入文件夹,找到以exe文件名命名的文件(没有后缀),这个就是目的文件. C0 d- k" u2 ~$ y, m/ }: M1 L! Z
2.jpg
8 O1 i2 @4 q$ n' O2). 用 010Editor 打开 struct,前八位就是我们想要的信息,将其复制
6 _$ S( }$ W4 U- ~ 3.jpg
6 r" ~+ X, y+ t; d; W) C8 e3). 用 010Editor 打开目的文件我这里是 abc_text,将上一步复制的信息插入到开头( I, P& g6 _: m9 K5 G/ l0 }
修改前:( c5 L& k! x& Q* G( @
4.jpg
/ Z( F# Y1 ]1 e  C6 H修改后:3 i( J5 N3 r8 @1 a
5.jpg
' s  @( H' t8 D$ w1 Y, g4). 将目的文件我这里是 abc_text,添加pyc的后缀
9 a3 u5 [# j( @2 {" x* u' Z. o第三步:逆向目的文件.pyc
  y* u. i3 N1 m7 z! u5 ?: q1). 其实这里已经可以使用了。了解python的都知道pyc是py文件编译后的二进制文件,因此如果想要分析源码还得继续逆向成.py文件
: `2 E) i, {" Y; K5 ~ 6.jpg * q" c9 a( |9 n# N! j- N
2). uncompyle6逆向pyc文件" e! W8 W+ o6 N& E$ C
uncompyle6 abc_text.pyc > abc_text.py
7.jpg 8.jpg
0 J: d" _9 b, x3 ?- |7 C 9.jpg - V0 `5 n0 h& N' |0 m& \
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|paopaomj.COM ( 渝ICP备18007172号|渝公网安备50010502503914号 )

GMT+8, 2025-11-29 05:02

Powered by paopaomj X3.5 © 2016-2025 sitemap

快速回复 返回顶部 返回列表