1. 程式人生 > >python類中的內建函式

python類中的內建函式

__init__():
__init__方法在類的一個物件被建立時,馬上執行。這個方法可以用來對你的物件做一些你希望的初始化。注意,這個名稱的開始和結尾都是雙下劃線。
程式碼例子:

#!/usr/bin/python
# Filename: class_init.py
class Person:
    def __init__(self, name):
        self.name = name
    def sayHi(self):
        print 'Hello, my name is', self.name

p = Person('Swaroop')
p.sayHi()

輸出:
Hello, my name is Swaroop

   說明:__init__方法定義為取一個引數name(以及普通的引數self)。在這個__init__裡,我們只是建立一個新的域,也稱為name。注意它們是兩個不同的變數,儘管它們有相同的名字。點號使我們能夠區分它們。最重要的是,我們沒有專門呼叫__init__方法,只是在建立一個類的新例項的時候,把引數包括在圓括號內跟在類名後面,從而傳遞給__init__方法。這是這種方法的重要之處。現在,我們能夠在我們的方法中使用self.name域。這在sayHi方法中得到了驗證。

__new__():
__new__()在__init__()之前被呼叫,用於生成例項物件.利用這個方法和類屬性的特性可以實現設計模式中的單例模式.單例模式是指建立唯一物件嗎,單例模式設計的類只能例項化一個物件.

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class Singleton(object):
    __instance = None                       # 定義例項

    def __init__(self):
        pass

    def __new__(cls, *args, **kwd):         # 在__init__之前呼叫
        if Singleton.__instance is None:    # 生成唯一例項
            Singleton.__instance = object.__new__(cls, *args, **kwd)
        return Singleton.__instance

   

__getattr__()、__setattr__()和__getattribute__():
當讀取物件的某個屬性時,python會自動呼叫__getattr__()方法.例如,fruit.color將轉換為fruit.__getattr__(color).當使用賦值語句對屬性進行設定時,python會自動呼叫__setattr__()方法.__getattribute__()的功能與__getattr__()類似,用於獲取屬性的值.但是__getattribute__()能提供更好的控制,程式碼更健壯.注意,python中並不存在__setattribute__()方法.
程式碼例子:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class Fruit(object):
    def __init__(self, color = "red", price = 0):
        self.__color = color
        self.__price = price
       
    def __getattribute__(self, name):               # 獲取屬性的方法
        return object.__getattribute__(self, name)

    def __setattr__(self, name, value):
        self.__dict__[name] = value

if __name__ == "__main__":
    fruit = Fruit("blue", 10)
    print fruit.__dict__.get("_Fruit__color")       # 獲取color屬性
    fruit.__dict__["_Fruit__price"] = 5
    print fruit.__dict__.get("_Fruit__price")       # 獲取price屬性

   

__getitem__():
如果類把某個屬性定義為序列,可以使用__getitem__()輸出序列屬性中的某個元素.假設水果店中銷售多鍾水果,可以通過__getitem__()方法獲取水果店中的沒種水果
程式碼例子:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class FruitShop:
     def __getitem__(self, i):      # 獲取水果店的水果
         return self.fruits[i]      

if __name__ == "__main__":
    shop = FruitShop()
    shop.fruits = ["apple", "banana"]
    print shop[1]
    for item in shop:               # 輸出水果店的水果
        print item,

輸出為:
banana
apple banana

   

__str__():
__str__()用於表示物件代表的含義,返回一個字串.實現了__str__()方法後,可以直接使用print語句輸出物件,也可以通過函式str()觸發__str__()的執行.這樣就把物件和字串關聯起來,便於某些程式的實現,可以用這個字串來表示某個類
程式碼例子:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class Fruit:     
    '''Fruit類'''               #為Fruit類定義了文件字串
    def __str__(self):          # 定義物件的字串表示
        return self.__doc__

if __name__ == "__main__":
    fruit = Fruit()
    print str(fruit)            # 呼叫內建函式str()出發__str__()方法,輸出結果為:Fruit類
    print fruit                 #直接輸出物件fruit,返回__str__()方法的值,輸出結果為:Fruit類

   

__call__():
在類中實現__call__()方法,可以在物件建立時直接返回__call__()的內容.使用該方法可以模擬靜態方法
程式碼例子:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class Fruit:
    class Growth:        # 內部類
        def __call__(self):
            print "grow ..."

    grow = Growth()      # 呼叫Growth(),此時將類Growth作為函式返回,即為外部類Fruit定義方法grow(),grow()將執行__call__()內的程式碼
if __name__ == '__main__':
    fruit = Fruit()
    fruit.grow()         # 輸出結果:grow ...
    Fruit.grow()         # 輸出結果:grow ...

 內建方法  說明
 __init__(self,...)  初始化物件,在建立新物件時呼叫
 __del__(self)  釋放物件,在物件被刪除之前呼叫
 __new__(cls,*args,**kwd)  例項的生成操作
 __str__(self)  在使用print語句時被呼叫
 __getitem__(self,key)  獲取序列的索引key對應的值,等價於seq[key]
 __len__(self)  在呼叫行內函數len()時被呼叫
 __cmp__(stc,dst)  比較兩個物件src和dst
 __getattr__(s,name)  獲取屬性的值
 __setattr__(s,name,value)  設定屬性的值
 __delattr__(s,name)  刪除name屬性
 __getattribute__()  __getattribute__()功能與__getattr__()類似
 __gt__(self,other)  判斷self物件是否大於other物件
 __lt__(slef,other)  判斷self物件是否小於other物件
 __ge__(slef,other)  判斷self物件是否大於或者等於other物件
 __le__(slef,other)  判斷self物件是否小於或者等於other物件
 __eq__(slef,other)  判斷self物件是否等於other物件
 __call__(self,*args)  把例項物件作為函式呼叫