本文實例講述了python物件及物件導向技術。分享給大家供大家參考,具體如下:
1 先看一個例子. 本章將講解這個範例程式:
檔案: fileinfo.py:
"""Framework for getting filetype-specific metadata. Instantiate appropriate class with filename. Returned object acts like a dictionary, with key-value pairs for each piece of metadata. import fileinfo info = fileinfo.MP3FileInfo("/music/ap/mahadeva.mp3") print "\n".join(["%s=%s" % (k, v) for k, v in info.items()]) Or use listDirectory function to get info on all files in a directory. for info in fileinfo.listDirectory("/music/ap/", [".mp3"]): ... Framework can be extended by adding classes for particular file types, e.g. HTMLFileInfo, MPGFileInfo, DOCFileInfo. Each class is completely responsible for parsing its files appropriately; see MP3FileInfo for example. """ import os import sys from UserDict import UserDict def stripnulls(data): "strip whitespace and nulls" return data.replace("{post.content}", "").strip() class FileInfo(UserDict): "store file metadata" def __init__(self, filename=None): UserDict.__init__(self) self["name"] = filename class MP3FileInfo(FileInfo): "store ID3v1.0 MP3 tags" tagDataMap = {"title" : ( 3, 33, stripnulls), "artist" : ( 33, 63, stripnulls), "album" : ( 63, 93, stripnulls), "year" : ( 93, 97, stripnulls), "comment" : ( 97, 126, stripnulls), "genre" : (127, 128, ord)} def __parse(self, filename): "parse ID3v1.0 tags from MP3 file" self.clear() try: fsock = open(filename, "rb", 0) try: fsock.seek(-128, 2) tagdata = fsock.read(128) finally: fsock.close() if tagdata[:3] == "TAG": for tag, (start, end, parseFunc) in self.tagDataMap.items(): self[tag] = parseFunc(tagdata[start:end]) except IOError: pass def __setitem__(self, key, item): if key == "name" and item: self.__parse(item) FileInfo.__setitem__(self, key, item) def listDirectory(directory, fileExtList): "get list of file info objects for files of particular extensions" fileList = [os.path.normcase(f) for f in os.listdir(directory)] fileList = [os.path.join(directory, f) for f in fileList if os.path.splitext(f)[1] in fileExtList] def getFileInfoClass(filename, module=sys.modules[FileInfo.__module__]): "get file info class from filename extension" subclass = "%sFileInfo" % os.path.splitext(filename)[1].upper()[1:] return hasattr(module, subclass) and getattr(module, subclass) or FileInfo return [getFileInfoClass(f)(f) for f in fileList] if __name__ == "__main__": for info in listDirectory("/music/_singles/", [".mp3"]): print "\n".join(["%s=%s" % (k, v) for k, v in info.items()]) print
2 使用from module import 導入模組
我們先前學的導入模組是用下邊的語法:
import 模組名稱
這樣在需要使用該模組中的東西時. 要透過模組名稱.XXX 的形式. 例如:
#>>> import types >>> types.FunctionType <type 'function'> >>> FunctionType
Traceback (most recent call last): File "<interactive input>", line 1, in <module> NameError: name 'FunctionType' is not defined
>>> from types import FunctionType
##這樣導入的名字就可以不透過模組名稱直接使用. 如:
>>> FunctionType <type 'function'>
3 類別的定義
定義類別的語法:
class 類別名稱:
pass
或
class 類別名稱(基底類別清單) :
pass
其中的pass 是Python的關鍵字. 表示什麼也不做.
類別也可以有類別文檔. 如果有的話. 他應該是類別定義中的第一個東西. 如:
class A(B) : " this is class A. "
類別的建構子是:
__init__
#不過. 準確的說。這只能算是建立該類別對象後. 自動執行的方法. 執行這個函數時. 物件已初始化了.
例如:
class A(B) : "this is class A. " def __init__ (self): B.__init__(self)
這裡為類別A 定義了一個建構方法. 並且在其中呼叫了基底類別B的建構方法.
要注意的是. 在Python中.建構衍生類別時. 並不會"自動"的呼叫基底類別的建構方法. 需要的話必須明確寫出.
所有的類別方法. 第一個參數都是用來接收this指標. 習慣上這個參數的名字是self.
呼叫時不要傳遞這個參數. 它會自動被加上的.
但是在像上邊的建構子中. 呼叫基底類別的__init()時. 這個參數必須明確地給出.
4 類別的實例化
實例化一個類別和其它語言相似. 只把它的類別名稱當作一個函數呼叫就行了. 而沒有其它語言的new之類.
類別名稱(參數表)
其中參數表中不必給出__init__的第一個參數self.
例如:
a = A()
我們可以透過類別或類別的實例查看該類別的文件. 這透過它們的__doc__屬性. 如:
>>> A.__doc__ 'this is class A. ' >>> a.__doc__ 'this is class A. '
我們也可以透過類別的實例來得到它的類別. 這透過它的__class__屬性. 如:
>>> a.__class__ <class __main__.A at 0x011394B0>
建立了類別的實例後. 我們不用擔心回收的問題. 垃圾回收會根據引用計數自動銷毀不用的物件.
Python中. 類別的資料成員也沒有專門的聲明語句. 而是在賦值的時候"突然產生"的. 例如:
class A : def __init__(self) : self.data = []
>>> class A: ... def __init__(self): ... self.li = range(5) ... def __getitem__(self, i): ... return self.li[-i] ... >>> a = A() >>> print a[1]
def __setitem__(self, key, item): self.li[key] = item
#
def __repr__(self): return repr(self.li)
repr(a)
def __cmp__(self, x): if isinstance(x, A): return cmp(self.li, x.li)
a = A() b = A() a == b
def __len__(self): return len(self.li)
用它可以指定一個你希望的邏輯長度值.
def __delitem__(self, key): del self.li[key]
class A : l = [1, 2, 3]
A.l
a.__class__.l
Python中也有"私有"這個概念:
私有函數不可以從它們的模組外邊被呼叫.
私有類別方法不能從它們的類別外邊被呼叫.
私有屬性不能從它們的類別外邊被存取.
Python中只有私有和公有兩種. 沒有保護的概念. 而區分公有還是私有是看函數. 類別方法. 類別屬性的名字.
私有的東西的名字以__ 開始. (但前邊說的專用方法(如__getitem__)不是私有的).
更多python物件及物件導向技術相關文章請關注PHP中文網!