中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python中import與from import有什么區別

發布時間:2021-09-24 16:46:29 來源:億速云 閱讀:175 作者:小新 欄目:開發技術

這篇文章主要介紹Python中import與from import有什么區別,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

系統自帶模塊(庫)

```cpp
import re
target = 'abc1234xyz'
re.search('(\d+)', target)
但有時候,你可能會看到某些人這樣寫代碼:

```python
from re import search
target = 'abc1234xyz'
search('(\d+)', target)

那么這兩種導入方式有什么區別呢?

我們分別使用type函數來看看他們的類型:

>>> import re
>>> type(re)
<class 'module'>
>>> from re import search
>>> type(search)
<class 'function'>

可以看到,直接使用import re導入的re它是一個module類,也就是模塊。我們把它成為正則表達式模塊。而當我們from re import search時,這個search是一個function類,我們稱呼它為search 函數。
一個模塊里面可以包含多個函數。
如果在你的代碼里面,你已經確定只使用search函數,不會再使用正則表達式里面的其他函數了,那么你使用兩種方法都可以,沒什么區別。
但是,如果你要使用正則表達式下面的多個函數,或者是一些常量,那么用第一種方案會更加簡潔清晰。

例如:

import re
re.search('c(.*?)x', flags=re.S)
re.sub('[a-zA-Z0-9]', '***', target, flags=re.I)

在這個例子中,你分別使用了re.search,re.sub,re.S和re.I。后兩者是常量,用于忽略換行符和大小寫。
但是,如果你使用from re import search, sub, S, I來寫代碼,那么代碼就會變成這樣:

import re
search('c(.*?)x', flags=S)
sub('[a-zA-Z0-9]', '***', target, flags=I)

看起來雖然簡潔了,但是,一旦你的代碼行數多了以后,你很容易忘記S和I這兩個變量是什么東西。而且我們自己定義的函數,也很有可能取名為sub或者search,從而覆蓋正則表達式模塊下面的這兩個同名函數。這就會導致很多難以覺察的潛在 bug。
再舉一個例子。Python 的 datetime模塊,我們可以直接import datetime,此時我們導入的是一個datetime模塊,

輸出為:class‘module'

但是如果你寫為from datetime import datetime,那么你導入的datetime是一個type類:

輸出為:class‘type'

因為這種方式導入的datetime,它就是Python 中的一種類型,用于表示包含日期和時間的數據。

這兩種導入方式導入的datetime,雖然名字一樣,但是他們的意義完全不一樣,請大家觀察下面兩種寫法:

import datetime
now = datetime.datetime.now()
one_hour_ago = now - datetime.timedelta(hours=1)
from datetime import datetime, timedelta
now = datetime.now()
one_hour_ago = now - timedelta(hours=1)

第二種寫法看似簡單,但實則改動起來卻更為麻煩。例如我還需要增加一個變量today用于記錄今日的日期。

對于第一段代碼,我們只需要增加一行即可:

today = datetime.date.today()

但對于第二行來說,我們需要首先修改導入部分的代碼:

from datetime import datetime, timedelta, date
然后才能改代碼:today = date.today()

這樣一來你就要修改兩個地方,反倒增加了負擔。

第三方庫

在使用某些第三方庫的代碼里面,我們會看到類似這樣的寫法:

from lxml.html import fromstring

selector = fromstring(HTML)
但是我們還可以寫為:

from lxml import html

selector = html.fromstring(HTML)
但是,下面這種寫法會導致報錯:

import lxml
selector = lxml.html.fromstring(HTML)
那么這里的lxml.html又是什么東西呢?

這種情況多常見于一些特別大型的第三方庫中,這種庫能處理多種類型的數據。例如lxml它既能處理xml的數據,又能處理html的數據,于是這種庫會劃分子模塊,lxml.html模塊專門負責html相關的數據。

動手試試

在使用某些第三方庫的代碼里面,我們會看到類似這樣的寫法:

 from lxml.html import fromstring
 selector = fromstring(HTML)

但是我們還可以寫為:

from lxml import html
selector = html.fromstring(HTML)

但是,下面這種寫法會導致報錯:

import lxml
selector = lxml.html.fromstring(HTML)

那么這里的lxml.html又是什么東西呢?
這種情況多常見于一些特別大型的第三方庫中,這種庫能處理多種類型的數據。例如lxml它既能處理xml的數據,又能處理html的數據,于是這種庫會劃分子模塊,lxml.html模塊專門負責html相關的數據。

自己來實現多種導入方法
我們現在自己來寫代碼,實現這多種導入方法。
我們創建一個文件夾DocParser,在里面分別創建兩個文件main.py和util.py,他們的內容如下:

util.py文件:

def write():
    print('write 函數被調用!')
main.py文件:
import util
util.write()

現在我們把main.py的導入方式修改一下(結果與上面相同):

from util import write
write()

現在,我們來創建一個文件夾microsoft,里面再添加一個文件parse.py:

from util import write
write()

此時我們在 main.py中對它進行調用:

def read():
    print('我是 microsoft 文件夾下面的 parse.py 中的 read函數')

我們也可以用另一種方法:

from microsoft import parse
parse.read()

但是,你不能直接導入microsoft

import microsoft
microsoft.parse.read

無論你使用的是import xxx還是from xxx.yyy.zzz.www import qqq,你導入進來的東西,要不就是一個模塊(對應到.py 文件的文件名),或者是某個.py 文件中的函數名、類名、變量名。

無論是import xxx還是from xxx import yyy,你導入進來的都不能是一個文件夾的名字。

可能有這樣一種情況,就是某個函數名與文件的名字相同,例如:

在 microsoft文件夾里面有一個microsoft.py文件,這個文件里面有一個函數叫做microsoft,那么你的代碼可以寫為:

from microsoft import microsoft`
microsoft.microsoft()
但請注意分辨,這里你導入的還是模塊,只不過microsoft.py文件名與它所在的文件夾名恰好相同而已。

以上是“Python中import與from import有什么區別”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

高淳县| 通榆县| 达尔| 宁明县| 本溪市| 池州市| 合阳县| 中超| 靖江市| 太康县| 石城县| 封开县| 永州市| 米泉市| 通河县| 通许县| 承德市| 台山市| 浙江省| 调兵山市| 汉沽区| 德昌县| 吉木萨尔县| 修文县| 长春市| 昌乐县| 竹北市| 宣恩县| 阆中市| 旬邑县| 密云县| 肥乡县| 永春县| 铜鼓县| 平远县| 蓬莱市| 宿州市| 迭部县| 浪卡子县| 大埔区| 平安县|