有時候,python 處理import 的行為有些詭異。
比如下面的目錄結構。
test目錄下有一個叫common的目錄, test的子目錄packA下也有一個同名目錄。
當在subA目錄下的sa1.py中試圖from common.logger import 時發(fā)現(xiàn)import的是test目錄下的common, 而不是packA目錄下的common. 打印sys.path發(fā)現(xiàn)test/common路徑并不在里面, 反而packA/common是存在的。
為避免糾纏,將packA.common下的logger.py改名為sublogger.py, 再from common.sublogger import 就與期望一致了。
這種問題深究比較費勁, 保險一點的做法還是同一個項目下盡量不要使用同名文件,自己看起來也會更清晰。
test/ # root folder
common/
__init__.py
logger.py
packA/ # package packA
__init__.py
common/
logger.py
subA/ # subpackage subA
__init__.py
sa1.py
sa2.py