淺析Python打包時(shí)包含靜態(tài)文件處理方法
使用場景
- 已搭建了PyPI私有庫,上傳公共庫包含靜態(tài)文件,如需要使用sql靜態(tài)文件初始化數(shù)據(jù)庫。
- 打包python包,給其他人使用,但項(xiàng)目中包含靜態(tài)文件,如html。
解決步驟
- 解決靜態(tài)文件讀取問題
- 解決靜態(tài)文件打包問題
環(huán)境
Python3.8
PyCharm 2020
demo項(xiàng)目為例
- 創(chuàng)建項(xiàng)目
- 展示靜態(tài)文件讀取問題
- 解決方案
- 展示靜態(tài)文件打包問題
- 解決方案
1. 創(chuàng)建項(xiàng)目
創(chuàng)建一個(gè)demo項(xiàng)目(text-setup),目錄如下
test-setup
demo
\_\_init\_\_.pydemo.pydemo.txt
/demo/demo.txt
The text is from demo.txt.
/demo/demo.py
import os def get_txt(): """使用原始打開io方式打開""" with open('demo.txt', 'r', encoding='utf-8') as f: return f.read() def get_demo_txt(): """修改獲取路徑方式,使用io打開""" current_dir = os.path.dirname(__file__) file_path = os.path.join(current_dir, 'demo.txt') with open(file_path, 'r', encoding='utf-8') as f: return f.read() if __name__ == "__main__": """類內(nèi)測試,均無異常""" print("get_demo_txt() :", get_demo_txt()) # get_demo_txt() : The text is from demo.txt. print("get_txt() :", get_txt()) # get_txt() : The text is from demo.txt.
在當(dāng)前路徑下執(zhí)行demo.py文件沒有異常(使用PyCharm直接右鍵run)
2. 展示靜態(tài)文件讀取問題
在根目錄(或其他任意除demo.py文件路徑)執(zhí)行上面的demo.py文件就會(huì)報(bào)錯(cuò)
$ python demo/demo.py get_demo_txt() : The text is from demo.txt. Traceback (most recent call last): File "demo/demo.py", line 21, in <module> print("get_txt() :", get_txt()) # get_txt() : The text is from demo.txt. File "demo/demo.py", line 6, in get_txt with open('demo.txt', 'r', encoding='utf-8') as f: FileNotFoundError: [Errno 2] No such file or directory: 'demo.txt'
明顯看出
- 直接使用相對路徑讀取靜態(tài)文件的方式報(bào)錯(cuò)
- 使用os.path.dirname(\_\_file\_\_)獲取當(dāng)前python文件路徑并拼接的方式不會(huì)報(bào)錯(cuò)
3. 解決方案
使用os.path.dirname(\_\_file\_\_)的方式去獲取當(dāng)前python文件路徑,再去拼接靜態(tài)文件的路徑
demo中將get_txt()方法刪除,繼續(xù)進(jìn)行以下打包demo
4. 展示靜態(tài)文件打包問題
打包,創(chuàng)建打包配置文件
/setup.py
from setuptools import find_packages, setup setup( name='demo', version='1.0.0', packages=find_packages(), zip_sage=False, )
執(zhí)行打包命令
$ python setup.py sdist
打開打包信息文件,內(nèi)容如下
/demo.egg-info/SOURCES.txt
setup.py demo/__init__.py demo/demo.py demo.egg-info/PKG-INFO demo.egg-info/SOURCES.txt demo.egg-info/dependency_links.txt demo.egg-info/top_level.txt
可以看出,demo.txt并不在資源文件中,可以實(shí)際試一下,其他項(xiàng)目引用這個(gè)文件執(zhí)行獲取文件也將報(bào)錯(cuò)FileNotFoundError
5. 解決方案
修改打包配置文件
/setup.py
from setuptools import find_packages, setup setup( name='demo', version='1.0.0', packages=find_packages(), zip_sage=False, include_package_data=True, # 打包包含靜態(tài)文件標(biāo)識 )
增加配置文件
/MANIFEST.in
include demo/demo.txt
最終文件目錄
test-setup
demo
\_\_init\_\_.pydemo.pydemo.txtsetup.pyMANIFEST.in
再次執(zhí)行打包命令
$ python setup.py sdist
打開打包信息文件,內(nèi)容如下
/demo.egg-info/SOURCES.txt
MANIFEST.in setup.py demo/__init__.py demo/demo.py demo/demo.txt demo.egg-info/PKG-INFO demo.egg-info/SOURCES.txt demo.egg-info/dependency_links.txt demo.egg-info/top_level.txt
可以看到demo.txt已經(jīng)在打包信息當(dāng)中,引用這個(gè)包也不會(huì)報(bào)錯(cuò)了
參考資料:
Creating a Source Distribution
Flask docs - Make the Project Installable
到此這篇關(guān)于Python打包時(shí)包含靜態(tài)文件處理方法的文章就介紹到這了,更多相關(guān)Python打包靜態(tài)文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python數(shù)據(jù)擬合與廣義線性回歸算法學(xué)習(xí)
這篇文章主要為大家詳細(xì)介紹了Python數(shù)據(jù)擬合與廣義線性回歸算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12Python實(shí)例一個(gè)類背后發(fā)生了什么
Python實(shí)例一個(gè)類背后發(fā)生了什么,本文為大家一一列出,感興趣的朋友可以參考一下2016-02-02django authenticate用戶身份認(rèn)證的項(xiàng)目實(shí)踐
Django的contrib.auth模塊中的authenticate()函數(shù)用于對用戶的憑據(jù)進(jìn)行身份驗(yàn)證,本文就來介紹一下django authenticate用戶身份認(rèn)證的使用,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08Python數(shù)學(xué)建模StatsModels統(tǒng)計(jì)回歸之線性回歸示例詳解
這篇文章主要為大家介紹了Python數(shù)學(xué)建模中StatsModels統(tǒng)計(jì)回歸之線性回歸的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10PyTorch和Keras計(jì)算模型參數(shù)的例子
今天小編就為大家分享一篇PyTorch和Keras計(jì)算模型參數(shù)的例子,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01keras實(shí)現(xiàn)多GPU或指定GPU的使用介紹
這篇文章主要介紹了keras實(shí)現(xiàn)多GPU或指定GPU的使用介紹,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06Python 處理數(shù)據(jù)的實(shí)例詳解
這篇文章主要介紹了Python 處理數(shù)據(jù)的實(shí)例詳解的相關(guān)資料,這里主要介紹Python 常用的基礎(chǔ)知識并附實(shí)例,需要的朋友可以參考下2017-08-08