
Python中模塊與包有相同名字的處理方法
在編程開發(fā)中,個人覺得,只要按照規(guī)范去做,很少會出問題。剛開始學習一門技術(shù)時,的確會遇到很多的坑。踩的坑多了,這是好事,會學到更多東西,也會越來越覺得按照規(guī)范做的重要性,規(guī)范的制定就是用來規(guī)避問題的。有時候確實應(yīng)該聽聽有經(jīng)驗人的建議,不要一意孤行。這好像不是本文的重點,其實我重點是想表達,盡量按規(guī)范做事,這樣會少走很多彎路。
我現(xiàn)在使用的主力編程語言是 Python,在接觸 Python 至今,我感覺我踩的坑還是極少的,基本上沒有遇到什么奇怪的問題。實際上,這并不是一件好事,不踩坑,很多躺在暗處的知識點你不會了解,所以也很難成長。幸好,有一些會踩坑的同事。
一同事問我,在 Python 中,如果一個模塊和一個包同名時,是不是只能導入包,如果要導入模塊該怎么辦。他的意思大概是這樣的,在項目的同一級目錄下,有一個 foo.py 文件和一個 foo/ 目錄,如果 import foo 會導入 foo/ 的內(nèi)容而不是 foo.py 的內(nèi)容。
被問到這個問題時,我首先感覺到的是詫異,這明顯是存在歧義的。如果是我,肯定不會把模塊名和包名設(shè)計成一樣的名字,因為本質(zhì)上來說在導入的時候沒法區(qū)分到底要導入誰。除非系統(tǒng)有特別的規(guī)定,例如,規(guī)定這種情況只能導入包。
我的潛意識里認為這里應(yīng)該報錯,Python 解釋器不知道要導入誰。但是,同事告訴我,別人的代碼是這么寫的,而且在這種情況下會默認導入包。那就是可以的咯,而且解釋器已經(jīng)規(guī)定這種情況會總是導入包。
為了驗證下這一點,我寫了個簡單的項目,項目結(jié)構(gòu)如下:
.
├── main.py
└── same
├── api
│ └── __init__.py
├── auth
│ └── __init__.py
├── auth.py
└── __init__.py
其中:
same/api/__init__/py 的內(nèi)容:
from .. import auth
same/auth/__init__.py 的內(nèi)容:
auth_str = "This is str in package!"
same/auth.py 的內(nèi)容:
auth_str = "This is str in module!"
main.py 的內(nèi)容:
from __future__ import print_function
from same.api import auth
# Script starts from here
if __name__ == "__main__":
print(auth.auth_str)
稍微有些復(fù)雜,哈哈,主要是同事那兒大致的結(jié)構(gòu)是這樣的,這里是為更好的模擬下。我在 same.auth 包中定義了一個 auth_str
字符串,又在同名的 same.auth 模塊中定義了一個同名的 auth_str 字符串,然后在 same.api 包嘗試導入 auth,最后在
main.py 嘗試輸出 same.api.auth.auth_str,看看到底哪個字符串會被打印。同時嘗試用 Python2 和
Python3 執(zhí)行 main.py,得到的結(jié)果都是:
This is str in package!
這里驗證了我們的猜想是正確的,解釋器的確只導入了包中內(nèi)容。但是,我并不知道是否有官方的資料說明就是這樣的,所以我不敢確信,萬一這只是巧合呢。
于是,我開始查資料來驗證這一結(jié)論。我就說實話吧,對于一個英文水平爛到你無法想象的我,只能先嘗試用百度搜索下答案了。事實是,用百度往往都是遺憾的。片刻后,無果,我只能硬著頭皮嘗試英文搜索了。于是,在 stackoverflow 上找到了如下提問:
How python deals with module and package having the same name?
其中有一個人回答說 Python 官方文檔中在描述模塊搜索路徑時提到了這一點:https://docs.python.org/3/tutorial/modules.html#the-module-search-path.
文檔中有如下一段描述:
After initialization, Python programs can modify sys.path. The
directory containing the script being run is placed at the beginning of
the search path, ahead of the standard library path. This means that
scripts in that directory will be loaded instead of modules of the same
name in the library directory. This is an error unless the replacement
is intended. See section Standard Modules for more information.
也就是說,目錄在庫的搜索路徑下會首先被搜索,這就意味著目錄會代替同名的模塊被加載。
這下終于放心了,之前的結(jié)論得到證實。在 Python 中,如果嘗試導入同名的模塊和包時,包會被導入。這種情況下,如果想要導入模塊,恐怕要用一些
‘hack' 的方法,上面提到的 stackoverflow
帖下有一些示例可以參考。當然,最好的方法是避免這樣的設(shè)計,這樣你就不會花那么長時間去查資料,也不會花那么長時間來寫類似于本文的文章。
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
LSTM 模型輸入長度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)家族中,長短期記憶網(wǎng)絡(luò)(LSTM)憑借其解決長序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報考條件詳解與準備指南? ? 在數(shù)據(jù)驅(qū)動決策的時代浪潮下,CDA 數(shù)據(jù)分析師認證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計的實用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實施重大更新。 此次更新旨在確保認 ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務(wù)的價值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡稱 BI)深度融合的時代,BI ...
2025-07-10SQL 在預(yù)測分析中的應(yīng)用:從數(shù)據(jù)查詢到趨勢預(yù)判? ? 在數(shù)據(jù)驅(qū)動決策的時代,預(yù)測分析作為挖掘數(shù)據(jù)潛在價值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點,而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報考到取證的全攻略? 在數(shù)字經(jīng)濟蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢性檢驗:捕捉數(shù)據(jù)背后的時間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢性檢驗如同一位耐心的偵探,專注于從單 ...
2025-07-09year_month數(shù)據(jù)類型:時間維度的精準切片? ? 在數(shù)據(jù)的世界里,時間是最不可或缺的維度之一,而year_month數(shù)據(jù)類型就像一把精準 ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應(yīng)用與實戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗:數(shù)據(jù)趨勢與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準確捕捉數(shù)據(jù)的趨勢變化以及識別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認證作為國內(nèi)權(quán)威的數(shù)據(jù)分析能力認證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應(yīng)對策略? 長短期記憶網(wǎng)絡(luò)(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的一種變體,憑借獨特的門控機制,在 ...
2025-07-07統(tǒng)計學方法在市場調(diào)研數(shù)據(jù)中的深度應(yīng)用? 市場調(diào)研是企業(yè)洞察市場動態(tài)、了解消費者需求的重要途徑,而統(tǒng)計學方法則是市場調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書考試全攻略? 在數(shù)字化浪潮席卷全球的當下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準確性的基礎(chǔ) ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03