python編譯pyc文件的過程解析
什么是pyc文件
pyc是一種二進(jìn)制文件,是由py文件經(jīng)過編譯后,生成的文件,是一種byte code,py文件變成pyc文件后,加載的速度有所提高,而且pyc是一種跨平臺的字節(jié)碼,是由python的虛擬機(jī)來執(zhí)行的,這個(gè)是類似于JAVA或者.NET的虛擬機(jī)的概念。pyc的內(nèi)容,是跟python的版本相關(guān)的,不同版本編譯后的pyc文件是不同的,2.5編譯的pyc文件,2.4版本的 python是無法執(zhí)行的。
什么是pyo文件
pyo是優(yōu)化編譯后的程序 python -O 源文件即可將源程序編譯為pyo文件
什么是pyd文件
pyd是python的動(dòng)態(tài)鏈接庫。
為什么需要pyc文件
這個(gè)需求太明顯了,因?yàn)閜y文件是可以直接看到源碼的,如果你是開發(fā)商業(yè)軟件的話,不可能把源碼也泄漏出去吧?所以就需要編譯為pyc后,再發(fā)布出去。當(dāng)然,pyc文件也是可以反編譯的,不同版本編譯后的pyc文件是不同的,根據(jù)python源碼中提供的opcode,可以根據(jù)pyc文件反編譯出 py文件源碼,網(wǎng)上可以找到一個(gè)反編譯python2.3版本的pyc文件的工具,不過該工具從python2.4開始就要收費(fèi)了,如果需要反編譯出新版本的pyc文件的話,就需要自己動(dòng)手了(俺暫時(shí)還沒這能力–),不過你可以自己修改python的源代碼中的opcode文件,重新編譯 python,從而防止不法分子的破解。
生成單個(gè)pyc文件
python就是個(gè)好東西,它提供了內(nèi)置的類庫來實(shí)現(xiàn)把py文件編譯為pyc文件,這個(gè)模塊就是 py_compile 模塊。
使用方法非常簡單,如下所示,直接在idle中,就可以把一個(gè)py文件編譯為pyc文件了。(假設(shè)在windows環(huán)境下)
通過IDLE操作如下
## 單個(gè)文件測試 >>> import py_compile >>> py_compile.compile(r'D:\hello.py') 'D:\\__pycache__\\hello.cpython-39.pyc' >>>
# 單個(gè)文件 import py_compile py_compile.compile(r'腳本.py') # 多個(gè)文件 import compileall compileall.compile_dir(r'腳本文件所在目錄')
-命令行操作如下
# 單個(gè)文件 python -m py_compile 腳本.py # 多個(gè)文件 python -m compileall 腳本文件所在目錄
如下圖是編譯多個(gè)腳本(其實(shí)是忘記加路徑了,直接編譯了當(dāng)前目錄,尷…,)

運(yùn)行pyc
python 腳本.py
_pycache__文件夾
解釋器首先將其編譯為字節(jié)碼(這是過度簡化)并將其存儲(chǔ)在__pycache__文件夾中。如果你查看那里你會(huì)發(fā)現(xiàn)一堆文件在項(xiàng)目文件夾中共享.py文件的名稱,只有它們的擴(kuò)展名為.pyc。它們分別是程序文件的字節(jié)碼編譯版本。
盡管產(chǎn)生了編譯文件,但是這些文件與源代碼不在同一目錄,可能會(huì)帶來調(diào)用問題。因此常常使用如下方式產(chǎn)生同級目錄下的.pyc文件:
python -m compileall -b . # 在腳本所在目錄下運(yùn)行
發(fā)布python 程序
編譯生成pyc文件,建議增加-O優(yōu)化項(xiàng)
python3 -O -m compileall -b .
刪除py文件
find . -name "*.py"|xargs rm -rf
刪除__pycache__目錄
find . -name "__pycache__" |xargs rm -rf
打成tar包
cd ..
tar -cjvf xxx.1.1.0.0.tar.bz2 xxx
參考文檔
https://docs.python.org/3.9/library/compileall.html
https://finthon.com/python-pyc/
到此這篇關(guān)于python編譯pyc文件的文章就介紹到這了,更多相關(guān)python pyc文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
pandas讀取HTML和JSON數(shù)據(jù)的實(shí)現(xiàn)示例
Pandas可以直接讀取html和JSON數(shù)據(jù),本文就來介紹一下pandas讀取HTML和JSON數(shù)據(jù)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),感興趣的可以了解一下2024-01-01
Python實(shí)現(xiàn)在數(shù)字中添加千位分隔符的方法小結(jié)
在數(shù)據(jù)處理和數(shù)據(jù)可視化中,經(jīng)常需要對大數(shù)值進(jìn)行格式化,其中一種常見的需求是在數(shù)字中添加千位分隔符,本文為大家整理了三種常見方法,希望對大家有所幫助2024-01-01
python網(wǎng)絡(luò)編程之進(jìn)程詳解
這篇文章主要為大家介紹了python網(wǎng)絡(luò)編程之進(jìn)程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01
Python使用xlrd實(shí)現(xiàn)讀取合并單元格
這篇文章主要介紹了Python使用xlrd實(shí)現(xiàn)讀取合并單元格,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
python使用 multiprocessing 多進(jìn)程處理批量數(shù)據(jù)的示例代碼
這篇文章主要介紹了使用 multiprocessing 多進(jìn)程處理批量數(shù)據(jù)的示例代碼,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
終于明白tf.reduce_sum()函數(shù)和tf.reduce_mean()函數(shù)用法

