Python本身就內(nèi)置了很多非常有用的模塊,只要安裝完畢,這些模塊就可以立刻使用。
我們以?xún)?nèi)建的sys模塊為例,編寫(xiě)一個(gè)hello的模塊:
#!/usr/bin/env python# -*- coding: utf-8 -*-' a test module '__author__ = 'Michael Liao'import sysdef test(): args = sys.argv if len(args)==1: print 'Hello, world!' elif len(args)==2: print 'Hello, %s!' % args[1] else: print 'Too many arguments!'if __name__=='__main__': test()
第1行和第2行是標(biāo)準(zhǔn)注釋?zhuān)?行注釋可以讓這個(gè)hello.py文件直接在Unix/Linux/Mac上運(yùn)行,第2行注釋表示.py文件本身使用標(biāo)準(zhǔn)UTF-8編碼;
第4行是一個(gè)字符串,表示模塊的文檔注釋?zhuān)魏文K代碼的第一個(gè)字符串都被視為模塊的文檔注釋?zhuān)?/p>
第6行使用__author__變量把作者寫(xiě)進(jìn)去,這樣當(dāng)你公開(kāi)源代碼后別人就可以瞻仰你的大名;
以上就是Python模塊的標(biāo)準(zhǔn)文件模板,當(dāng)然也可以全部刪掉不寫(xiě),但是,按標(biāo)準(zhǔn)辦事肯定沒(méi)錯(cuò)。
后面開(kāi)始就是真正的代碼部分。
你可能注意到了,使用sys模塊的第一步,就是導(dǎo)入該模塊:
import sys
導(dǎo)入sys模塊后,我們就有了變量sys指向該模塊,利用sys這個(gè)變量,就可以訪問(wèn)sys模塊的所有功能。
sys模塊有一個(gè)argv變量,用list存儲(chǔ)了命令行的所有參數(shù)。argv至少有一個(gè)元素,因?yàn)榈谝粋€(gè)參數(shù)永遠(yuǎn)是該.py文件的名稱(chēng),例如:
運(yùn)行python hello.py獲得的sys.argv就是['hello.py'];
運(yùn)行python hello.py Michael獲得的sys.argv就是['hello.py', 'Michael]。
最后,注意到這兩行代碼:
if __name__=='__main__': test()
當(dāng)我們?cè)诿钚羞\(yùn)行hello模塊文件時(shí),Python解釋器把一個(gè)特殊變量__name__置為_(kāi)_main__,而如果在其他地方導(dǎo)入該hello模塊時(shí),if判斷將失敗,因此,這種if測(cè)試可以讓一個(gè)模塊通過(guò)命令行運(yùn)行時(shí)執(zhí)行一些額外的代碼,最常見(jiàn)的就是運(yùn)行測(cè)試。
我們可以用命令行運(yùn)行hello.py看看效果:
$ python hello.pyHello, world!$ python hello.py MichaelHello, Michael!
如果啟動(dòng)Python交互環(huán)境,再導(dǎo)入hello模塊:
$ pythonPython 2.7.5 (default, Aug 25 2013, 00:04:04) [GCC 4.2.1 Compatible Apple LLVM 5.0 (clang-500.0.68)] on darwinType "help", "copyright", "credits" or "license" for more information.>>> import hello>>>
導(dǎo)入時(shí),沒(méi)有打印Hello, word!,因?yàn)闆](méi)有執(zhí)行test()函數(shù)。
調(diào)用hello.test()時(shí),才能打印出Hello, word!:
>>> hello.test()Hello, world!
別名
導(dǎo)入模塊時(shí),還可以使用別名,這樣,可以在運(yùn)行時(shí)根據(jù)當(dāng)前環(huán)境選擇最合適的模塊。比如Python標(biāo)準(zhǔn)庫(kù)一般會(huì)提供StringIO和cStringIO兩個(gè)庫(kù),這兩個(gè)庫(kù)的接口和功能是一樣的,但是cStringIO是C寫(xiě)的,速度更快,所以,你會(huì)經(jīng)常看到這樣的寫(xiě)法:
try: import cStringIO as StringIOexcept ImportError: # 導(dǎo)入失敗會(huì)捕獲到ImportError import StringIO
這樣就可以?xún)?yōu)先導(dǎo)入cStringIO。如果有些平臺(tái)不提供cStringIO,還可以降級(jí)使用StringIO。導(dǎo)入cStringIO時(shí),用import ... as ...指定了別名StringIO,因此,后續(xù)代碼引用StringIO即可正常工作。
還有類(lèi)似simplejson這樣的庫(kù),在Python 2.6之前是獨(dú)立的第三方庫(kù),從2.6開(kāi)始內(nèi)置,所以,會(huì)有這樣的寫(xiě)法:
try: import json # python >= 2.6except ImportError: import simplejson as json # python <= 2.5
由于Python是動(dòng)態(tài)語(yǔ)言,函數(shù)簽名一致接口就一樣,因此,無(wú)論導(dǎo)入哪個(gè)模塊后續(xù)代碼都能正常工作。
作用域
在一個(gè)模塊中,我們可能會(huì)定義很多函數(shù)和變量,但有的函數(shù)和變量我們希望給別人使用,有的函數(shù)和變量我們希望僅僅在模塊內(nèi)部使用。在Python中,是通過(guò)_前綴來(lái)實(shí)現(xiàn)的。
正常的函數(shù)和變量名是公開(kāi)的(public),可以被直接引用,比如:abc,x123,PI等;
類(lèi)似__xxx__這樣的變量是特殊變量,可以被直接引用,但是有特殊用途,比如上面的__author__,__name__就是特殊變量,hello模塊定義的文檔注釋也可以用特殊變量__doc__訪問(wèn),我們自己的變量一般不要用這種變量名;
類(lèi)似_xxx和__xxx這樣的函數(shù)或變量就是非公開(kāi)的(private),不應(yīng)該被直接引用,比如_abc,__abc等;
之所以我們說(shuō),private函數(shù)和變量“不應(yīng)該”被直接引用,而不是“不能”被直接引用,是因?yàn)镻ython并沒(méi)有一種方法可以完全限制訪問(wèn)private函數(shù)或變量,但是,從編程習(xí)慣上不應(yīng)該引用private函數(shù)或變量。
private函數(shù)或變量不應(yīng)該被別人引用,那它們有什么用呢?請(qǐng)看例子:
def _private_1(name): return 'Hello, %s' % namedef _private_2(name): return 'Hi, %s' % namedef greeting(name): if len(name) > 3: return _private_1(name) else: return _private_2(name)
我們?cè)谀K里公開(kāi)greeting()函數(shù),而把內(nèi)部邏輯用private函數(shù)隱藏起來(lái)了,這樣,調(diào)用greeting()函數(shù)不用關(guān)心內(nèi)部的private函數(shù)細(xì)節(jié),這也是一種非常有用的代碼封裝和抽象的方法,即:
外部不需要引用的函數(shù)全部定義成private,只有外部需要引用的函數(shù)才定義為public。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注