解決python調(diào)用自己文件函數(shù)/執(zhí)行函數(shù)找不到包問題
寫python程序的時(shí)候很多人習(xí)慣創(chuàng)建一個(gè)utils.py文件,存放一些經(jīng)常使用的函數(shù),方便其他文件調(diào)用,同時(shí)也更好的管理一些通用函數(shù),方便今后使用。或是兩個(gè)文件之間的class或是函數(shù)調(diào)用情況。
就像下面的工程目錄一樣:
工程目錄
Project ... src main.py utils.py test.py ...
python調(diào)用其他文件中的函數(shù)
在main.py文件中加入一下語句即可調(diào)用utils.py下面的函數(shù):‘’
import src.utils as utilsX, y = utils.load_data()
開發(fā)python的習(xí)慣使用IDE,比如pycharm,pydev等,在這些IDE中使用方便,可以輕松的更換解釋器,在文件右鍵運(yùn)行即可,沒有問題。使用上述的方法也不會(huì)有其它問題。
可是當(dāng)你現(xiàn)在本地寫code,然后發(fā)現(xiàn)本地計(jì)算資源不夠,想到了服務(wù)器,服務(wù)器是ubuntu的。
于是乎用ssh [email protected].登錄服務(wù)器,然后選擇一個(gè)本人的文件工程目錄下面用scp命令將本地代碼拷貝過去,或是用git clone https://github.com/xxx將代碼倉庫代碼拷貝到服務(wù)器上,然后cd Project/,敲下python main.py,發(fā)現(xiàn)報(bào)出No module named ‘src’.錯(cuò)誤,于是上網(wǎng)上搜代碼,有人給出解決方案“把工程目錄里面加入sys就行了”
import syssys.path.append(’D:/pythonworkspace’)
沒錯(cuò)在本地是能解決問題,但是換個(gè)別的盤呢?又得改代碼。在服務(wù)器上呢,What? D盤?ubuntu哪來的D盤?還得改代碼
原因
在文件中寫下面兩句python代碼
import sysprint(sys.path)
分別用pycharm和shell執(zhí)行,發(fā)現(xiàn)兩個(gè)輸出的是不一樣的:
pycharm輸出:
D:pythonworkspaceProject
shell輸出:
D:pythonworkspacrProjecrtsrc
有人覺得,原來是這個(gè)樣子,于是乎cd ..,然后python src/test.py,可是發(fā)現(xiàn)還是會(huì)報(bào)錯(cuò),找不到module。
原因是pycharm執(zhí)行文件的時(shí)候路徑是整個(gè)工程下的路徑,而shell執(zhí)行文件的時(shí)候是執(zhí)行文件所在的路徑,不是shell所在的文件路徑。
解決
所以正確的姿勢是這個(gè)樣子
import syssys.path.append('..')
先把相對路徑轉(zhuǎn)換成絕對路徑,然后將絕對路徑加入系統(tǒng)變量中就行了。這樣就可以在不用的場景下使用python命令,和靈活的使用其他文件下的函數(shù)了,不會(huì)報(bào)錯(cuò)。如果包含多級目錄就繼續(xù)加sys.path.append('../..')
以上這篇解決python調(diào)用自己文件函數(shù)/執(zhí)行函數(shù)找不到包問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 推薦一個(gè)好看Table表格的css樣式代碼詳解2. 基于Surprise協(xié)同過濾實(shí)現(xiàn)短視頻推薦方法示例3. 不使用XMLHttpRequest對象實(shí)現(xiàn)Ajax效果的方法小結(jié)4. vue-electron中修改表格內(nèi)容并修改樣式5. 微信小程序?qū)崿F(xiàn)商品分類頁過程結(jié)束6. 以PHP代碼為實(shí)例詳解RabbitMQ消息隊(duì)列中間件的6種模式7. ASP新手必備的基礎(chǔ)知識(shí)8. AJAX實(shí)現(xiàn)文件上傳功能報(bào)錯(cuò)Current request is not a multipart request詳解9. PHP獲取時(shí)間戳等相關(guān)函數(shù)匯總10. ASP常用日期格式化函數(shù) FormatDate()
