
Python中模塊與包有相同名字的處理方法
在編程開發中,個人覺得,只要按照規范去做,很少會出問題。剛開始學習一門技術時,的確會遇到很多的坑。踩的坑多了,這是好事,會學到更多東西,也會越來越覺得按照規范做的重要性,規范的制定就是用來規避問題的。有時候確實應該聽聽有經驗人的建議,不要一意孤行。這好像不是本文的重點,其實我重點是想表達,盡量按規范做事,這樣會少走很多彎路。
我現在使用的主力編程語言是 Python,在接觸 Python 至今,我感覺我踩的坑還是極少的,基本上沒有遇到什么奇怪的問題。實際上,這并不是一件好事,不踩坑,很多躺在暗處的知識點你不會了解,所以也很難成長。幸好,有一些會踩坑的同事。
一同事問我,在 Python 中,如果一個模塊和一個包同名時,是不是只能導入包,如果要導入模塊該怎么辦。他的意思大概是這樣的,在項目的同一級目錄下,有一個 foo.py 文件和一個 foo/ 目錄,如果 import foo 會導入 foo/ 的內容而不是 foo.py 的內容。
被問到這個問題時,我首先感覺到的是詫異,這明顯是存在歧義的。如果是我,肯定不會把模塊名和包名設計成一樣的名字,因為本質上來說在導入的時候沒法區分到底要導入誰。除非系統有特別的規定,例如,規定這種情況只能導入包。
我的潛意識里認為這里應該報錯,Python 解釋器不知道要導入誰。但是,同事告訴我,別人的代碼是這么寫的,而且在這種情況下會默認導入包。那就是可以的咯,而且解釋器已經規定這種情況會總是導入包。
為了驗證下這一點,我寫了個簡單的項目,項目結構如下:
.
├── main.py
└── same
├── api
│ └── __init__.py
├── auth
│ └── __init__.py
├── auth.py
└── __init__.py
其中:
same/api/__init__/py 的內容:
from .. import auth
same/auth/__init__.py 的內容:
auth_str = "This is str in package!"
same/auth.py 的內容:
auth_str = "This is str in module!"
main.py 的內容:
from __future__ import print_function
from same.api import auth
# Script starts from here
if __name__ == "__main__":
print(auth.auth_str)
稍微有些復雜,哈哈,主要是同事那兒大致的結構是這樣的,這里是為更好的模擬下。我在 same.auth 包中定義了一個 auth_str
字符串,又在同名的 same.auth 模塊中定義了一個同名的 auth_str 字符串,然后在 same.api 包嘗試導入 auth,最后在
main.py 嘗試輸出 same.api.auth.auth_str,看看到底哪個字符串會被打印。同時嘗試用 Python2 和
Python3 執行 main.py,得到的結果都是:
This is str in package!
這里驗證了我們的猜想是正確的,解釋器的確只導入了包中內容。但是,我并不知道是否有官方的資料說明就是這樣的,所以我不敢確信,萬一這只是巧合呢。
于是,我開始查資料來驗證這一結論。我就說實話吧,對于一個英文水平爛到你無法想象的我,只能先嘗試用百度搜索下答案了。事實是,用百度往往都是遺憾的。片刻后,無果,我只能硬著頭皮嘗試英文搜索了。于是,在 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.
也就是說,目錄在庫的搜索路徑下會首先被搜索,這就意味著目錄會代替同名的模塊被加載。
這下終于放心了,之前的結論得到證實。在 Python 中,如果嘗試導入同名的模塊和包時,包會被導入。這種情況下,如果想要導入模塊,恐怕要用一些
‘hack' 的方法,上面提到的 stackoverflow
帖下有一些示例可以參考。當然,最好的方法是避免這樣的設計,這樣你就不會花那么長時間去查資料,也不會花那么長時間來寫類似于本文的文章。
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
CDA數據分析師證書考試體系(更新于2025年05月22日)
2025-05-26解碼數據基因:從數字敏感度到邏輯思維 每當看到超市貨架上商品的排列變化,你是否會聯想到背后的銷售數據波動?三年前在零售行 ...
2025-05-23在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25