本文目錄一覽:
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的,枉我熬夜給你答題。這種白痴樓主就不配在這裡問問題。
Python 中的import 機制
解釋器 在執行語句時,遵循作用域原則。因為這和作用域有關係, 如果在頂層導入模塊,此時它的作用域是全局的;如果在函數內部導入了模塊,那它的作用域只是局部的 ,不能被其它函數使用。如果其它函數也要用到這個模塊,還需要再次導入比較麻煩。
在用import語句導入模塊時最好按照這樣的順序:
絕對路徑 就是文件的真正存在的路徑,是指從硬盤的根目錄(盤符)開始,進行一級級目錄指向文件。
相對路徑 就是以當前文件為基準進行一級級目錄指向被引用的資源文件。
以下是常用的表示當前目錄和當前目錄的父級目錄的標識符
形如from moduleB import ClassB語句,根據Python內部import機制,執行細分步驟:
總結:from moduleB import ClassB有兩個過程,先from module,後import ClassB。
當然將moduleA.py語句 from moduleB import ClassB改為:import moduleB,將在第二次執行moduleB.py語句from moduleA import ClassA時報錯:ImportError: cannot import name 『classA』
在一個文件下同時有 init .py文件、和其他模塊文件時,該文件夾即看作一個包(package)。包的導入 和模塊導入基本一致,只是導入包時,會執行這個 init .py,而不是模塊中的語句。
而且,如果只是單純地導入包【形如:import xxx】,而包的 init .py中有沒有明確地的其他初始化操作,則:此包下的模塊 是不會被自動導入的。當然該包是會成功導入的,並將包名稱放入當前.py的Local命名空間中。
參考文章:
Python中import機制
Python 3.x可能是史上最詳解的【導入(import)】
在Python中以絕對路徑或者相對路徑導入文件的方法
Python的模塊引用和查找路徑
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 python
from IsDir import A
A.say()
輸出:
This is module A!
1.2 如果想調用moduleA,B,C,D呢?
方法1.
#!/usr/bin/env python
from IsDir import A
from IsDir import B
from IsDir import C
from IsDir import D
A.say()
B.say()
C.say()
D.say()
方法2.
#!/usr/bin/env python
import IsDir.A
import IsDir.B
import IsDir.C
import IsDir.D
from IsDir import *
A.say()
B.say()
C.say()
D.say()
錯誤示例1:
#!/usr/bin/env python
import IsDir.A
A.say()
錯誤示例2:
#!/usr/bin/env python
from 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 python
from IsDir import *
A.say()
B.say()
結果:
% python test.py
This is module A!
This is module B!
錯誤實例:
#!/usr/bin/env python
from 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.py
def say():
print “This is module A!”
後記:
謝謝這位同學,回答你的問題感覺很有收穫,順便又把python溫習了一遍。回頭把這些總結貼到我的blog上以上為手寫,望採納,共勉。
=============================================================
老子寫了這麼多居然採用了另一個簡陋的答案,mlgb的,枉我熬夜給你答題。這種白痴樓主就不配在這裡問問題。
python import什麼意思
是指在當前目錄,相對路徑下import某個模塊。 import 非常規的常見的用法有:
1、在sys.path里加入你要引用的目錄,甚至 ../的絕對目錄都可以。
2、absolute_import,可以按絕對路徑import某個模塊, 實際上這個東西好象不起作用。
至於from .XXX import yyy這種用法,在老的代碼里還是常見。其實沒有必要。因為import 本身就有這個功能。或者是用更直觀的方法importlib.import_module(module,parent)這樣不容易犯錯誤。
Random的作用
Random使用之前需要使用Randomize語句進行隨機數種子的初始化。RANDOM產生的是偽隨機數或者說是用一種複雜的方法計算得到的序列值,因此每次運算時需要一個不同的種子值。種子值不同,得到的序列值也不同。因此也就是真正的隨機數了。
RANDOM產生的是偽隨機數或者說是用一種複雜的方法計算得到的序列值,因此每次運算時需要一個不同的種子值。種子值不同,得到的序列值也不同。因此也就是真正的隨機數了。這也正是RANDOMIZE隨機初始化的作用。 VB里用 NEW RANDOM()來表示初始化。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/304245.html