99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀python中模塊查找的原理與方法詳解
python中模塊查找的原理與方法詳解
2017-09-15
收藏

python中模塊查找的原理與方法詳解

本文主要給大家介紹了關(guān)于python模塊查找的原理與方式,分享出來供大家參考學(xué)習(xí),下面話不多說,來一起看看詳細(xì)的介紹:
基礎(chǔ)概念
module
模塊, 一個(gè) py 文件或以其他文件形式存在的可被導(dǎo)入的就是一個(gè)模塊
package
包,包含有 __init__ 文件的文件夾
relative path
相對(duì)路徑,相對(duì)于某個(gè)目錄的路徑
absolute path
絕對(duì)路徑,全路徑
路徑查找
python 解釋器查找被引入的包或模塊
Python 解釋器是如何查找包和模塊的
Python 執(zhí)行一個(gè) py 文件,無論執(zhí)行的方式是用絕對(duì)路徑還是相對(duì)路徑,interpreter 都會(huì)把文件所在的 directory 加入 sys.path 這個(gè) list 中,Python 就是在 sys.path 中查找包和模塊的,sys.path 中的內(nèi)容本身又是又 Python 的環(huán)境變量決定。
code-1    

執(zhí)行表明相對(duì)路徑和絕對(duì)路徑都輸出相同的結(jié)果,而且無論哪種執(zhí)行方式,test.py 所在的文件夾都會(huì)被加入 sys.path 的首位,也就是索引為0的位置。

Python 解釋器查找包的順序是什么

解釋器查找包,首先搜索 built-in module,其次搜索 sys.path ,這樣的查找順序?qū)?huì)導(dǎo)致同名包或模塊被遮蔽。
code-2
    
#ls
├── os.py
├── test2.py
├── redis.py
#test2.py
import os
from redis import Redis
#execute test2.py
Traceback (most recent call last):
 File "/Users/x/workspace/blog-code/p2016_05_28_python_path_find/test2.py", line 1, in <module>
 from redis import Redis
ImportError: cannot import name Redis
由于 os 是 built-in module,即使在同目錄下有同名模塊,解釋器依然可以找到正確的 os 模塊,可以證實(shí) built-in module 不會(huì)被遮蔽,而 redis 屬于第三方模塊,默認(rèn)安裝位置是 Python 環(huán)境變量中的 site-packages,解釋器啟動(dòng)之后會(huì)將此目錄中的內(nèi)容加入 sys.path,由于當(dāng)前目錄會(huì)在 sys.path 的首位,當(dāng)前目錄的 redis 優(yōu)先被找到,site-packages 中的 redis 模塊被遮蔽了。

交互式執(zhí)行環(huán)境的查找順序

進(jìn)入交互式執(zhí)行環(huán)境,解釋器會(huì)自動(dòng)把當(dāng)前目錄加入 sys.path, 這時(shí)當(dāng)前目錄是以相對(duì)路徑的形式出現(xiàn)在 sys.path 中:    
>>> import os.path
>>> import sys
>>> os.path.abspath(sys.path[0])
'/Users/x/workspace/blog-code'
>>>
除此之外,其他與執(zhí)行一個(gè)文件是相同的。
模塊中的 __file__ 變量
__file__ is the pathname of the file from which the module was loaded, if it was loaded from a file. 如果一個(gè)模塊是從文件加載的,__file__ 就是該模塊的路徑名–Python Doc:
顧名思義,當(dāng)模塊以文件的形式出現(xiàn) __file__ 指的是模塊文件的路徑名,以相對(duì)路徑執(zhí)行 __file__ 是相對(duì)路徑,以絕對(duì)路徑執(zhí)行 __file__ 是絕對(duì)路徑。    
#test3.py
print __file__
#相對(duì)路徑執(zhí)行
python test3.py
test3.py
#絕對(duì)路徑執(zhí)行
python /Users/x/workspace/blog-code/p2016_05_28_python_path_find/test3.py
/Users/x/workspace/blog-code/p2016_05_28_python_path_find/test3.py
為了保證__file__ 每次都能準(zhǔn)確得到模塊的正確位置,最好對(duì)其再取一次絕對(duì)路徑 os.path.abspath(__file__) 。

交互式 shell 中的 __file__    
>>> __file__
Traceback (most recent call last):
 File "<input>", line 1, in <module>
NameError: name '__file__' is not defined

這是因?yàn)楫?dāng)前交互式shell的執(zhí)行并不是以文件的形式加載,所以不存在__file__ 這樣的屬性。

sys.argv[0] 變量

sys.argv[0] 是它用來獲取主入口執(zhí)行文件。    
#test.py
import sys
print __file__
print sys.argv[0]
以上 print 輸出相同的結(jié)果,因?yàn)橹鲌?zhí)行文件和__file__所屬的模塊是同一個(gè),當(dāng)我們改變?nèi)肟谖募?,區(qū)別就出現(xiàn)了。    
#test.py
import sys
print __file__
print sys.argv[0]
#test2.py
import test
#execute test2.py
/Users/x/workspace/blog-code/p2016_05_28_python_path_find/child/test.py #__file__
test2.py #sys.argv[0]
總的來說,sys.argv[0] 是獲得入口執(zhí)行文件路徑,__file__ 是獲得任意模塊文件的路徑。
sys.modules 的作用
既然 Python 是在 sys.path 中搜索模塊的,那載入的模塊存放在何處?答案就是 sys.modules。模塊一經(jīng)載入,Python 會(huì)把這個(gè)模塊加入 sys.modules 中供下次載入使用,這樣可以加速模塊的引入,起到緩存的作用。    
>>> import sys
>>> sys.modules['tornado']
Traceback (most recent call last):
 File "<input>", line 1, in <module>
KeyError: 'tornado'
>>> import tornado
>>> sys.modules['tornado']
<module 'tornado' from '/Users/x/python_dev/lib/python2.7/site-packages/tornado/__init__.pyc'>

前面說過 Python 解釋器啟動(dòng)之后,會(huì)把預(yù)先載入 built-in module,可以通過 sys.modules 驗(yàn)證。    
>>> sys.modules['os']
<module 'os' from '/Users/x/python_dev/lib/python2.7/os.pyc'>
>>>

借助 sys.modules 和 __file__,可以動(dòng)態(tài)獲取所有已加載模塊目錄和路徑。
    
>>> import os
>>> os.path.realpath(sys.modules['os'].__file__)
'/Users/x/python_dev/lib/python2.7/os.pyc'
>>> import tornado
>>> os.path.realpath(sys.modules['tornado'].__file__)
'/Users/x/python_dev/lib/python2.7/site-packages/tornado/__init__.pyc'    
def get_module_dir(name):
 path = getattr(sys.modules[name], '__file__', None)
 if not path
 raise AttributeError('module %s has not attribute __file__'%name)
 return os.path.dirname(os.path.abspath(path))

summary
總的來說,Python 是通過查找 sys.path 來決定包的導(dǎo)入,并且系統(tǒng)包優(yōu)先級(jí)>同目錄>sys.path,Python 中的特有屬性 __file__ 以及 sys.argv[0] ,sys.modules 都能幫助我們理解包的查找和導(dǎo)入概念,只要能正確理解 sys.path 的作用和行為,理解包的查找就不是難題了。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助

數(shù)據(jù)分析咨詢請(qǐng)掃描二維碼

若不方便掃碼,搜微信號(hào):CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個(gè)參數(shù)驗(yàn)證碼對(duì)象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個(gè)配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺(tái)檢測(cè)極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時(shí)表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請(qǐng)參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時(shí)完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請(qǐng)輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請(qǐng)輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }