如果使用python写了程序,有时候希望将程序打包成一个应用程序,如exe,这时候可以使用pyinstaller,来打包应用程序。
可以使用pip安装:

pip install pyinstaller

如果是使用pycharm平台,可以使用上面的pip安装,也可以直接插件安装:

python 反编译pyd python怎么反编译_django


安装好pyinstaller插件后,使用:

pyinstaller yourprogram.py

来打包你的程序。

python 反编译pyd python怎么反编译_python_02


python 反编译pyd python怎么反编译_python_03


输入指令,就开始自动打包,最后可以在输出文件夹里看到生成的main.exe文件:

python 反编译pyd python怎么反编译_反编译_04


上面就是打包的过程。

如果现在没有源程序,想要通过这个exe来反编译,就需要用到另一个插件:

pyinstxtractor.py

下载地址:https://sourceforge.net/projects/pyinstallerextractor/

下载好后,将这个程序与需要解包的exe程序放到一个文件夹。

python 反编译pyd python怎么反编译_python_05


pyinstxtractor.py的使用也很简单,在python的命令行终端或者pycharm的终端,进入当前文件夹:

python 反编译pyd python怎么反编译_python_06


python 反编译pyd python怎么反编译_django_07


这时候反编译第一步就完成了:

python 反编译pyd python怎么反编译_python_08


这里生成的应该是pyc文件,但这里需要进行一些手动的修改,然后进行下一步,也就是对.pyc文件再进行反编译。

自己测试了一下,也实现了,所以把后续步骤也写一下:

在利用pyinstxtractor.py反编译后,可以看到文件夹里出现了:main、struct这两个没有后缀的文件,这个main其实就是python的main,但是因为里面少了一些东西,所以需要打开这个main并添加上。这里需要用到另一个软件:010 editor

下载地址:https://www.sweetscape.com/010editor/

这个软件是收费软件,但是可以试用30天。

安装好010editor后,打开软件:

python 反编译pyd python怎么反编译_python_09


然后在软件中分别打开main和struct文件:

python 反编译pyd python怎么反编译_反编译_10


python 反编译pyd python怎么反编译_pycharm_11


仔细看这两个文件的信息,可以发现,main的第一行字节数据和struct的第二行一样,也就是struct比main多了前面一行也就是16个字节的数据(这个数量有可能不一样,以实际文件内容为准,也有可能是12个字节或者更少)。关于这个数据的内容的解释,可以去看一下网上其他更专业的解释,这边就不多说了(本人也不是很懂)。

将struct的第一行复制,然后再main这边插入到第一行前面,具体操作:010editor软件菜单栏的Edit,在下拉菜单中找到Insert/overwrite,然后选择insert bytes,设置首地址为0,长度为16(按自己的实际来写)。

python 反编译pyd python怎么反编译_pycharm_12


点击insert,就会在main插入一行空字节,然后选中第一行,将struct的第一行copy覆盖过来。完成点击保存,并将main保存成main.pyc文件,然后你就会在文件夹里看到:

python 反编译pyd python怎么反编译_python_13


这个就是main.pyc文件了。

接下来要将main.pyc还原成main.py,我看网上说可以用uncompyle6,但我实际测试了,这个模块支持py2.7-3.8,如果你用的是最新的3.9,用uncompyle6就不行。

有一种在线反编译工具:

https://tool.lu/pyc/

python 反编译pyd python怎么反编译_pycharm_14

图片中的程序就是我用pycharm写的,的确是完全反编译过来,不过,这个在线工具有时候也会编译不出来:

python 反编译pyd python怎么反编译_pycharm_15

基本上利用这样的一个流程,应该是能反编译一个使用python写的且打包成exe格式的程序的。