通過(guò)字符串導(dǎo)入 Python 模塊的方法詳解
我們平時(shí)導(dǎo)入第三方模塊的時(shí)候,一般使用的是 import 關(guān)鍵字,例如:
import scrapy from scrapy.spider import Spider
但是如果各位同學(xué)看過(guò) Scrapy 的 settings.py 文件,就會(huì)發(fā)現(xiàn)里面會(huì)通過(guò)字符串的方式來(lái)指定pipeline 和 middleware,例如:
DOWNLOADER_MIDDLEWARES = {
'Test.middlewares.ExceptionRetryMiddleware': 545,
'Test.middlewares.BOProxyMiddlewareV2': 543,
}
SPIDER_MIDDLEWARES = {
'Test.middlewares.LoggingRequestMiddleware': 543,
}
我們知道,這里的 Test.middlewares.ExceptionRetryMiddleware 實(shí)際上對(duì)應(yīng)了根目錄下面的 Test 文件夾里面的 middlewares.py 文件中的 ExceptionRetryMiddleware 類(lèi)。那么 Scrapy 是如何根據(jù)這個(gè)字符串,導(dǎo)入這個(gè)類(lèi)的呢?
在 Scrapy 源代碼中,我們可以找到 相關(guān)的代碼 :
def load_object(path):
"""Load an object given its absolute object path, and return it.
object can be a class, function, variable or an instance.
path ie: 'scrapy.downloadermiddlewares.redirect.RedirectMiddleware'
"""
try:
dot = path.rindex('.')
except ValueError:
raise ValueError("Error loading object '%s': not a full path" % path)
module, name = path[:dot], path[dot+1:]
mod = import_module(module)
try:
obj = getattr(mod, name)
except AttributeError:
raise NameError("Module '%s' doesn't define any object named '%s'" % (module, name))
return obj
根據(jù)這段代碼,我們知道,它使用了 importlib 模塊的 import_module 函數(shù):
首先根據(jù)字符串路徑最右側(cè)的 . 把字符串路徑分成兩個(gè)部分,例如: Test.middlewares.LoggingRequestMiddleware 分成 Test.middlewares 和 LoggingRequestMiddleware
使用 import_module 導(dǎo)入左邊的部分
從左邊部分通過(guò) getattr 獲得具體的類(lèi)
現(xiàn)在我們來(lái)測(cè)試一下。我們創(chuàng)建的測(cè)試文件結(jié)構(gòu)如下圖所示:
其中, pipelines.py 文件的內(nèi)容如下圖所示:
main.py 文件的內(nèi)容如下圖所示:
運(yùn)行 main.py ,可以看到 pipelines.py 中的 Pipeline 類(lèi)被成功執(zhí)行了,如下圖所示:
總結(jié)
以上所述是小編給大家介紹的通過(guò)字符串導(dǎo)入 Python 模塊的方法詳解,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
- python編程開(kāi)發(fā)之textwrap文本樣式處理技巧
- Python實(shí)現(xiàn)二分查找與bisect模塊詳解
- python實(shí)現(xiàn)二分查找算法
- Python使用re模塊正則提取字符串中括號(hào)內(nèi)的內(nèi)容示例
- Python查找數(shù)組中數(shù)值和下標(biāo)相等的元素示例【二分查找】
- Python之time模塊的時(shí)間戳,時(shí)間字符串格式化與轉(zhuǎn)換方法(13位時(shí)間戳)
- python fuzzywuzzy模塊模糊字符串匹配詳細(xì)用法
- Python二分查找+字符串模板+textwrap模塊,
相關(guān)文章
python 用遞歸實(shí)現(xiàn)通用爬蟲(chóng)解析器
這篇文章主要介紹了python 用遞歸實(shí)現(xiàn)通用爬蟲(chóng)解析器的方法,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-04-04
淺談PyTorch中in-place operation的含義
這篇文章主要介紹了淺談PyTorch中in-place operation的含義,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06
python使用requests庫(kù)提交multipart/form-data請(qǐng)求的方法詳解
multipart/form-data的基礎(chǔ)是post請(qǐng)求,即基于post請(qǐng)求來(lái)實(shí)現(xiàn)的 ,下面這篇文章主要給大家介紹了關(guān)于python使用requests庫(kù)提交multipart/form-data請(qǐng)求的相關(guān)資料,需要的朋友可以參考下2023-01-01
對(duì)python pandas讀取剪貼板內(nèi)容的方法詳解
今天小編就為大家分享一篇對(duì)python pandas讀取剪貼板內(nèi)容的方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
Python操作JSON文件的知識(shí)點(diǎn)整理
Python?提供了內(nèi)置的?json?模塊來(lái)處理?JSON?格式的文件。該模塊主要分為讀取和寫(xiě)入?JSON?文件。本文主要為大家整理了一些Python操作JSON文件的知識(shí)點(diǎn),需要的可以參考一下2023-01-01
Django模板報(bào)TemplateDoesNotExist異常(親測(cè)可行)
這篇文章主要介紹了Django模板報(bào)TemplateDoesNotExist異常(親測(cè)可行),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
使用SimpleITK讀取NII格式三維圖像及注意事項(xiàng)說(shuō)明
這篇文章主要介紹了使用SimpleITK讀取NII格式三維圖像及注意事項(xiàng)說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12

