在學(xué)習(xí)編程過(guò)程中,我一直遵循一個(gè)簡(jiǎn)單的思路,更好的寫(xiě)代碼,寫(xiě)出更好的代碼,python作為我的主要開(kāi)發(fā)工具,有必要深入了解下python標(biāo)準(zhǔn)庫(kù).
- 更好的利用標(biāo)準(zhǔn)庫(kù)中已經(jīng)有的輪子,提升自己的開(kāi)發(fā)效率.
- 標(biāo)準(zhǔn)庫(kù)的源碼一定是最pythonic,學(xué)習(xí)其pythonic的編碼風(fēng)格.
該系列文章全部基于python3.5,交互式環(huán)境全都基于Ipython 5.1.0
文章采用標(biāo)準(zhǔn)庫(kù)常用功能介紹,源碼分析(挑選重要的),應(yīng)用場(chǎng)景介紹(工程實(shí)踐較少,見(jiàn)諒^^)為組織方式.
sys模塊
sys模塊是最常用的和python解釋器交互的模塊,sys模塊可供訪問(wèn)由解釋器(interpreter)使用或維護(hù)的變量和與解釋器進(jìn)行交互的函數(shù)。
sys.argv
程序外部向程序內(nèi)部傳遞參數(shù)
test_argv.py
import sys
print(sys.argv)
print(sys.argv[0])
print(sys.argv[1])
$ python3 test_argv.py hello
['test_argv.py', 'hello']
test.py
hello
sys.argv 是一個(gè)列表對(duì)象,第一個(gè)元素永遠(yuǎn)是文件名,接下來(lái)依次是傳入的參數(shù),大家可以動(dòng)手實(shí)驗(yàn)多加幾個(gè)參數(shù).
這樣就實(shí)現(xiàn)了在運(yùn)行python腳本的時(shí)候從terminal往腳本里面?zhèn)鬟f參數(shù)
sys.path/sys.module
- sys.path 解釋器來(lái)搜索python包的路徑,sys.path[0]是該py文件的路徑
- sys.modules 一個(gè)已加載模塊的字典
In [1]: import sys
In [2]: sys.path
Out[2]:
['',
'/usr/lib/python35.zip',
'/usr/lib/python3.5',
'/usr/lib/python3.5/plat-x86_64-linux-gnu',
'/usr/lib/python3.5/lib-dynload',
'/home/zhangwenchao/.local/lib/python3.5/site-packages',
'/usr/local/lib/python3.5/dist-packages',
'/usr/lib/python3/dist-packages',
'/usr/lib/python3/dist-packages/IPython/extensions',
'/home/zhangwenchao/.ipython']
寫(xiě)好的py文件放在以上目錄下就可以被python解釋器搜索到,也可以這樣
sys.path.append('文件路徑')給解釋器增加搜索包的路徑
In [3]: sys.modules
Out[3]:
{'IPython': <module 'IPython' from '/usr/lib/python3/dist-packages/IPython/__init__.py'>,
'IPython.core': <module 'IPython.core' from '/usr/lib/python3/dist-packages/IPython/core/__init__.py'>,
'IPython.core.alias': <module 'IPython.core.alias' from '/usr/lib/python3/dist-packages/IPython/core/alias.py'>,
'IPython.core.application': <module 'IPython.core.application' from '/usr/lib/python3/dist-packages/IPython/core/application
......
}
sys.modules是一個(gè)全局字典 python啟動(dòng)后自動(dòng)加載的全局變量,導(dǎo)入新的模塊會(huì)自動(dòng)更新到這個(gè)字典中.刪除該字典可能會(huì)導(dǎo)致python不能正確運(yùn)行.
sys.exit(n)
python解釋器一般在執(zhí)行到py文件末尾的時(shí)候自動(dòng)退出,主動(dòng)調(diào)用sys.exit()可以在中途退出
test.py
import sys
print('1111111')
print('2222222')
sys.exit(1)
print('3333333')
print('4444444')
$ python3 test.py
1111111
2222222
本來(lái)應(yīng)該打印的3333333和4444444沒(méi)有打印,執(zhí)行到sys.exit()的時(shí)候就退出了,這和python解釋器執(zhí)行到文件末尾退出是一樣的,下面代碼具有相同的效果
test.py
print('1111111')
print('2222222')
raise SystemExit
print('3333333')
print('4444444')
sys.exc_info()
sys.exc_info()可以獲得當(dāng)前錯(cuò)誤的詳細(xì)信息
test.py
import sys
def err():
raise NameError('name error')
try:
err()
except Exception as e:
print(e)
exc_type, exc_value, exc_traceback_obj = sys.exc_info()
print(exc_type)
print(exc_value)
print(exc_traceback_obj)
$python3 test.py
name error
<class 'NameError'>
name error
<traceback object at 0x7f1e9ba611c8>
sys 還可以對(duì)解釋器的錯(cuò)誤堆棧追蹤進(jìn)行詳細(xì)信息的設(shè)置
python解釋器相關(guān)
- sys.api_version 解釋器的C的API版本
- sys.copyright 版權(quán)信息
- sys.platform 解釋器運(yùn)行的平臺(tái),我的是linux
- sys.version 解釋器的python版本
- sys.getrecursionlimit() 解釋器的最大遞歸深度,默認(rèn)為1000
- setrecursionlimit() 為解釋器設(shè)置最大遞歸深度