日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

在python中用import或者from_[转]python基础之---import与from...import....

發布時間:2023/12/19 python 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 在python中用import或者from_[转]python基础之---import与from...import.... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

簡單說說python import與from...import....(python模塊)

在python用import或者from...import來導入相應的模塊。模塊其實就一些函數和類的集合文件,它能實現一些相應的功能,當我們需要使用這些功能的時候,直接把相應的模塊導入到我們的程序中,我們就可以使用了。這類似于C語言中的include頭文件,Python中我們用import導入我們需要的模塊。

eg:

import sys

print('================Python import mode==========================');

print ('The command line arguments are:')

for i in sys.argv:

print (i)

print ('\n The python path',sys.path)

from sys import argv,path#導入特定的成員

print('================python from import===================================')

print('path:',path)

如果你要使用所有sys模塊使用的名字,你可以這樣:

from sys import *

print('path:',path)

從以上我們可以簡單看出:

############################

#導入mode,import與from...import的不同之處在于,簡單說:

# 如果你想要直接輸入argv變量到你的程序中而每次使用它時又不想打sys,

# 則可使用:from sys import argv

# 一般說來,應該避免使用from..import而使用import語句,

# 因為這樣可以使你的程序更加易讀,也可以避免名稱的沖突

###########################

在使用 from xxx import * 時,如果想精準的控制模塊導入的內容,可以使用 __all__ = [xxx,xxx] 來實現,例如:

two.py

__all__ = ['a','b'] #__為雙橫線

class two():

def __init__(self):

print('this is two')

a = 'this is two a'

b = 'this is two b'

if __name__=='__main__':

t = two()

one.py

from two import *

print a

print b

t = two()

這時,類two() 將不會被 import * 導入進來

關于Import中的路徑搜索問題

類似于頭文件,模塊也是需要系統的搜索路徑的,下面的命令即是系統默認的搜索路徑,當你導入一個模塊時,系統就會在下面的路徑列表中搜索相應的文件。

>>> print(sys.path)

['D:/xx/PythonSERVER/python31/Code', 'D:\\xx\\PythonSERVER\\python31\\Lib\\idlelib', 'C:\\WINDOWS\\system32\\python31.zip', 'D:\\xx\\PythonSERVER\\python31\\DLLs', 'D:\\xx\\PythonSERVER\\python31\\lib', 'D:\\xx\\PythonSERVER\\python31\\lib\\plat-win', 'D:\\xx\\PythonSERVER\\python31', 'D:\\xx\\PythonSERVER\\python31\\lib\\site-packages']

(從例表中,我們可以看到python會首先在當前工作目錄里去找)

如果沒有找到相應的內容,則報錯:

>>> import syss

Traceback (most recent call last):

File "D:/xxx/xxx/xx/Code/test.py", line 19, in

import syss

ImportError: No module named syss

當然,我們也可以自行添加要搜索路徑。調用列表的append方法即可:

import sys

sys.path.append('D:/xx/PythonSERVER/python31/Code')

創建自己的模塊

在創建之前,有一點需要說明一下:每個Python模塊都有它的__name__(就每個對象都自己的__doc__一樣)。通過__name__我們可以找出每一個模塊的名稱,一般__name__的值有種:1 一是主模塊名稱為:"__main__"(可以理解為直接運行的那個文件),2 那些被主模塊導入的模塊名稱為:文件名字(不加后面的.py)。有__name__是很有用的,因為我們可以通過 if __name__? == 'xxx' 判斷來執行那些模塊,那些模塊不被執行。另外:每個Python程序也是一個模塊。它擴展名為:.py擴展名。

下面,我們通過例子來說明:

首先:我們創建模塊:mymodel.py

#!/user/bin/python

#Filename:mymodel.py

version = '1.0'

def sayHello():

print ('Hello world')

def modelName():

return __name__#返回它自己的名稱

#end of model

以上語句注意:

1 這個模塊應該被放置在我們輸入它的程序的同一個目錄中,或者在sys.path所列目錄之一。

2 你已經看到,它與我們普通的Python程序相比并沒有什么特別之處

然后:我們在test.py中來調用此模塊:test.py

import sys,mymodel

sys.path.append('D:/xx/PythonSERVER/python31/Code')#提供搜索路徑

print(__name__) #此處打印主模塊的名稱:__main__

mymodel.sayHello()

print('Version',mymodel.version)

print('Model Name',mymodel.modelName())#打印被導入模塊的名稱: mymodel

我們使用from..import...

print('======================from.....import=====================================')

from mymodel import *

print(__name__)#此處打印主模塊的名稱:__main__

sayHello()

print('Version',version)

print('Model Name',modelName()) #打印被導入模塊的名稱: mymodel

以上語句注意:

1 我們可以通過import來導入多個模塊,用“,”(逗號)分隔。

2 注意import與from..import.....

創建自己的包

1 一個包的基本組織如下:

FC/

__init__.py

Libr/

__init__.py

one.py

two.py

....

Model/

__init__.py

one.py

....

在外部加載調用時,有以下方式:

#coding:utf-8

#加載方式一

import Fc.Libr.one

print Fc.Libr.one.a

#加載方式二

from Fc.Libr import one

print one.a

#加載方式三

from Fc.Libr.one import a

print a

#加載方式四

from Fc.Libr import *

print one.a

注意直接使用第四種方式是不能正確導入Libr下的one子模塊的,這就需要在Fc目錄下的__init__.py文件中定義好需要加載子模塊的名稱

Fc/Libr/__init__.py

__all__=['one','two'] #定義加載子模塊的名稱

在加載包模塊時,在import語句執行期時,遇到的所有__init__.py文件都會被執行,在上面代碼中

首先會執行Fc目錄中的__int__.py,然后執行Libr目錄中的__init__.py

2 子模塊加子模塊問題

同一包的相同目錄中:

#coding:utf-8

#加載方式一:使用完全限定名稱

from Fc.Libr import one

aa = 'libr two load one---'+one.a

#加載方式二:使用相對導入

from . import one

bb = 'libr two load one----'+one.b

方二中使用.來表示在同一級目錄中。

#加載方式三:(這種方式應當避免:最后找不到會轉移到標準庫)

import Fc.Libr.one

cc = 'libr two load one---'+Fc.Libr.one.a

在外部使用時:

#coding:utf-8

from Fc.Libr import *

print two.aa

print two.bb

同一包的不同目錄中:

#coding:utf-8

from ..Model import one

a = 'libr two load mode one---'+one.a

使用時:

#coding:utf-8

from Fc.Libr import *

print two.a

將輸出:libr two load mode one---fc model one

另外在導入一個包時,會定義一個特殊的變量__path__,該變量包含一個目錄列表。

__path__可通過__init__.py文件中包含的代碼訪問,最初包含的一項具有包的目錄名稱。我們可以

向__path__列表提供更多的目錄,以更改查找子模塊時使用的搜索路徑,大型項目中這個很有用。

特別說明

1? import執行加載源文件中所有語名(所以模塊是一個文件)。

2? import語句可以出現在程序中的任何位置。但是有一點是:無論import語句被使用了多少次,每個模塊中的代碼僅加載和執行一次,后續的import語句僅將模塊名稱綁定到前一次導入所創建的模塊對象上。

3? 使用sys.modules可查看當前加載的所有模塊。

總結

以上是生活随笔為你收集整理的在python中用import或者from_[转]python基础之---import与from...import....的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。