網站首頁 編程語言 正文
本文以Python3.8為例
1、 compileall py文件轉換為pyc
1.1、compileall命令行模式
不需要額外安裝,python自帶模塊。
可以利用Python -m的方式在命令行模式下編譯py文件。
python -m compileall 文件或路徑 可選項
比如要編譯當前工作目錄下的所有py文件:
python -m compileall .
或者:
python -m compileall .\
比如要編譯某個指定目錄sub\dir\下的所有py文件:
python -m compileall sub\dir\
如果只編譯某一個指定的test.py文件:
python -m compileall test.py
注意命令行模式下,如果不指明文件或路徑默認會將sys.path下的所有文件進行編譯!sys.path包括了當前工作目錄、Python安裝目錄、Python包目錄等。
使用上述編譯命令后會在py文件所在的同一級目錄下生成一個__pycache__文件夾,在該__pycache__文件夾下會根據py文件名稱和Python版本號生成對應的pyc文件,比如test.py文件對應會生成一個__pycache__\test.cpython-38.pyc文件。
下面這個例子編譯new文件夾下的py文件,通過tree命令可以看到編譯后的文件結構:
E:\juzicode>python -m compileall new ??
Listing 'new'...
Compiling 'new\\build.py'...
Compiling 'new\\test.py'...
?
E:\juzicode>tree new /f
卷 xyz 的文件夾 PATH 列表
卷序列號為 000000
E:\JUZICODE\NEW
│ ?build.py
│ ?test.py
│
└─__pycache__
? ? ? ? build.cpython-38.pyc
? ? ? ? test.cpython-38.pyc ? ?#生成的pyc文件所在的位置
使用python -m compileall -h可以看到幫助文檔和可選項的含義:
-l:不遞歸編譯子文件夾;
-r level:指定編譯文件夾的層數,優先級高于-l;level=0表示不進入下一層,levle=1表示進入第一層,level=2表示進入第二層,以此類推。
-f:強制重新編譯一次,即使文件的時間戳沒有更新,當沒有使用-f選項時,如果py文件的時間戳更早于pyc文件,不會觸發編譯過程;
-x REG:根據REG表示的正則式選擇文件編譯。
1.2、compileall源碼模式
compileall還提供源碼方式編譯py文件,同樣會生成__pycache__文件夾及在該文件夾下的pyc文件。
首先導入compileall模塊,使用compileall.compile_file(‘py文件名稱’)編譯py文件:
import compileall
compileall.compile_file('test.py')
-----結果:
Compiling 'test.py'...
另外也可以使用compileall.compile_dir(‘路徑名稱’)編譯某個路徑下的py文件:
import compileall
compileall.compile_dir('new')
-----結果:
Listing 'new'...
Listing 'new\\mod'...
Compiling 'new\\mod\\mod.py'...
Compiling 'new\\test.py'...
Compiling 'new\\xyz.py'...
還有一個不常用的方法是compileall.compile_path()會編譯sys.path路徑下的py文件。
2、uncompyle6 pyc轉換為py文件
2.1、安裝
可以使用uncompyle6將pyc文件轉換回py文件,在Python3.8中需要額外安裝uncompyle6模塊:
pip install uncompyle6
安裝之后就會在Python安裝目錄的scripts文件夾下生成一個uncompyle6.exe的可執行文件:
一般在安裝時添加過安裝目錄到環境變量下,這時就可以直接運行uncompyle6。
2.2、uncompyle6命令行模式
下面這個例子用命令“uncompyle6 test.pyc” 解析test.pyc文件并輸出解析后的內容:
E:\juzicode\pyc-2-py>uncompyle6 ?test.pyc
# uncompyle6 version 3.8.0
# Python bytecode 3.8.0 (3413)
# Decompiled from: Python 3.8.3 (tags/v3.8.3:6f8c832, May 13 2020, 22:37:02) [MSC v.1924 64 bit (AMD64)]
# Embedded file name: test.py
# Compiled at: 2022-05-01 20:51:57
# Size of source mod 2**32: 60 bytes
import sys
print(sys.version)
# okay decompiling test.pyc
從解析的內容可以看到使用的uncompyle6的版本號、Python的版本號、編譯成pyc時的編譯時間、源代碼的內容等。
上面這種命令方式只是將解析后的內容輸出到控制臺,如果要將解析結果生成py文件,則可以將打印輸出重定向到文件里:
uncompyle6 test.pyc > test.py
這樣在當前目錄下就生成了一個test.py文件,文件內容和前述例子打印輸出內容一致。
另外一種方法是使用-o選項+目標文件路徑+pyc文件(可以是多個),在目標文件路徑下輸出和pyc同名的py文件:
E:\juzicode\pyc-2-py>uncompyle6 ?-o .\ ?build.pyc ?test.pyc
build.pyc --
test.pyc -- decompiled 2 files: 2 okay, 0 failed
# decompiled 2 files: 2 okay, 0 failed
2.3、uncompyle6代碼模式
先用open方法創建一個文件實例pf,再使用decompile_file(‘pyc文件’,pf)函數將pyc文件轉換為py文件:
import uncompyle6 as uc
pf = open("test.py", "w")
uc.decompile_file("test.pyc", pf)
轉換后的文件和用命令行方式內容一樣,包含了編譯時間、Python版本、源代碼等。
總結
原文鏈接:https://blog.csdn.net/juzicode00/article/details/124580320
相關推薦
- 2022-02-15 H5移動端大轉盤抽獎插件, 簡單、易用、無依賴
- 2022-05-25 Windows系統修改Jenkins端口號_win服務器
- 2022-05-29 Android?App如何防止抓包_Android
- 2022-07-13 簡單的利用boost.python 和 boost.numpy 實現python和c++之間數據通信
- 2022-12-15 C#入參使用引用類型要加ref的原因解析_C#教程
- 2022-04-28 WPF依賴屬性用法詳解_實用技巧
- 2022-12-27 React生命周期函數圖解介紹_React
- 2023-07-08 如何讓element-ui的el-row內容居中(水平垂直)
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支