本文目錄一覽:
python import同級目錄報錯
pycharm 里的.py文件import 同級目錄里的其他.py文件報錯,如圖
![SKCGMF0J $DWGU)2Q@YRZMF.png
原因:pycharm不會將當前的文件目錄自動加入自己PYTHONPATH
解決:將當前的文件目錄設置為source root(右鍵點擊工程目錄,Mark Directory as- Source Root),然後去File-Settings搜索Python Console確保source root路徑已加入 PYTHONPATH
步驟一:
步驟二:
參考:
添加python的import搜索目錄
如果我們要添加自己的搜索目錄,有兩種方法:
一是直接修改sys.path,添加要搜索的目錄:
第二種方法是設置環境變量PYTHONPATH,該環境變量的內容會被自動添加到模塊搜索路徑中。設置方式與設置Path環境變量類似。注意只需要添加你自己的搜索路徑,Python自己本身的搜索路徑不受影響。
python中import是什麼意思?
Python中的import語句是用來調用模塊的。
一、module
通常模塊為一個文件,直接使用import來導入就好了。可以作為module的文件類型有"py”、".pyo”、"pyc”、"pyd”、"so”、"dll”。
二、package
通常包總是一個目錄,可以使用import導入包,或者from + import來導入包中的部分模塊。
包目錄下為首的一個文件便是_init__py。然後是一些模塊文件和子目錄,假如子目錄中也有_init__py那麼它就是這個包的子包了。
優點
簡單:Python是一種代表簡單主義思想的語言。閱讀一個良好的Python程序就感覺像是在讀英語一樣。它使你能夠專註於解決問題而不是去搞明白語言本身。
易學:Python極其容易上手,因為Python有極其簡單的說明文檔。
易讀、易維護:風格清晰劃一、強制縮進。
速度快:Python的底層是用C語言寫的,很多標準庫和第三方庫也都是用C寫的,運行速度非常快。
免費、開源:Python是FLOSS(自由/開放源碼軟件)之一。
使用者可以自由地發布這個軟件的拷貝、閱讀它的源代碼、對它做改動、把它的一部分用於新的自由軟件中。FLOSS是基於一個團體分享知識的概念。
python import路徑是什麼?
以下為純手打,下面給幾個demos:
說明:
modules所在的目錄在python里叫package, 下面是一個名為 IsDir的package(實際上就是一個目錄), package下面有4個modules(A, B, C, D)和一個__init__.py文件,目錄結構如下:
IsDir/A.py B.py C.py D.py __init__.py大體來講,有兩種方法可以調用某目錄下(包括遞歸目錄)的modules.
一. __init__.py為空時
1.1 以下為調用moduleA的代碼:
#!/usr/bin/env pythonfrom IsDir import AA.say()輸出:
This is module A!1.2 如果想調用moduleA,B,C,D呢?
方法1.
#!/usr/bin/env pythonfrom IsDir import Afrom IsDir import Bfrom IsDir import Cfrom IsDir import DA.say()B.say()C.say()D.say()方法2.
#!/usr/bin/env pythonimport IsDir.Aimport IsDir.Bimport IsDir.Cimport IsDir.Dfrom IsDir import *A.say()B.say()C.say()D.say()錯誤示例1:
#!/usr/bin/env pythonimport IsDir.AA.say()錯誤示例2:
#!/usr/bin/env pythonfrom IsDir import *A.say()錯誤的原因:
IsDir/目錄下__init__.py 為空時,直接import IsDir.A 或者from IsDir import *是無效的.
從官方文檔里可以看到,__init__.py 里沒有__all__ = [module1,module2,…]時,
from IsDir import * 只能保證IsDir被imported, 所以此時IsDir里的modules是無法被imported,此時只有如我上面所寫的代碼所示才能正確執行,否則是錯誤的。官方解釋為:import IsDir.A並無任何意義,只有接着執行from IsDir import *後,import IsDir.A語句里的module A才會被定義,所以完整的調用因改為: 1. import IsDir.A 2. from IsDir import *。二. __init__.py用all=[…]指定該package下可以被imported進去的module
__init__.py里寫入如下內容:
% cat IsDir/__init__.py__all__ = [“A”,”B”]然後使用之:
#!/usr/bin/env pythonfrom IsDir import *A.say()B.say()結果:
% python test.py This is module A!This is module B!錯誤實例:
#!/usr/bin/env pythonfrom IsDir import *C.say()以上示例之所以錯誤,是因為C並沒有在__all__ = [“A”,”B”]里制定,由此可見,package IsDir下面的__init__.py里,__all__=[…]具有隔離modules的作用。
補充:
module A, B, C,D里我分別只定義了一個method, 例如,以下為module A的code:
% cat IsDir/A.pydef say(): print “This is module A!”後記:
謝謝這位同學,回答你的問題感覺很有收穫,順便又把python溫習了一遍。回頭把這些總結貼到我的blog上以上為手寫,望採納,共勉。
=============================================================
老子寫了這麼多居然採用了另一個簡陋的答案,mlgb的,枉我熬夜給你答題。這種白痴樓主就不配在這裡問問題。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/157692.html