Python 類可以定義專用方法,專用方法是在特殊情況下或當(dāng)使用特別語(yǔ)法時(shí)由 Python 替你調(diào)用的,而不是在代碼中直接調(diào)用(象普通的方法那樣)。
創(chuàng)新互聯(lián)主要從事網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)宜良,10多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):18980820575
.1 __init__
類似于構(gòu)造函數(shù)
#!/usr/local/bin/python
class Study:
def __init__(self,name=None):
self.name = name
def say(self):
print self.name
study = Study("Badboy")
study.say()
.2 __del__
類似于析構(gòu)函數(shù)
#!/usr/local/bin/python
class Study:
def __init__(self,name=None):
self.name = name
def __del__(self):
print "Iamaway,baby!"
def say(self):
print self.name
study = Study("zhuzhengjun")
study.say()
.3__repr__
使用repr(obj)的時(shí)候,會(huì)自動(dòng)調(diào)用__repr__函數(shù),該函數(shù)返回對(duì)象字符串表達(dá)式,
用于重建對(duì)象,如果eval(repr(obj))會(huì)得到一個(gè)對(duì)象的拷貝。
#!/usr/local/bin/python
class Study:
def __init__(self,name=None):
self.name = name
def __del__(self):
print "Iamaway,baby!"
def say(self):
print self.name
def __repr__(self):
return "Study('jacky')"
study = Study("zhuzhengjun")
study.say()
print type(repr(Study("zhuzhengjun"))) # str
print type(eval(repr(Study("zhuzhengjun")))) # instance
study = eval(repr(Study("zhuzhengjun")))
study.say()
.4__str__
Python能用print語(yǔ)句輸出內(nèi)建數(shù)據(jù)類型。有時(shí),程序員希望定義一個(gè)類,要求它的對(duì)象也能用print語(yǔ)句輸出。Python類可定義特殊方法__str__,為類的對(duì)象提供一個(gè)不正式的字符串表示。如果類的客戶程序包含以下語(yǔ)句:
print objectOfClass
那么Python會(huì)調(diào)用對(duì)象的__str__方法,并輸出那個(gè)方法所返回的字符串。
#!/usr/local/bin/python
class PhoneNumber:
def __init__(self,number):
self.areaCode=number[1:4]
self.exchange=number[6:9]
self.line=number[10:14]
def __str__(self):
return "(%s) %s-%s"%(self.areaCode,self.exchange,self.line)
def test():
newNumber=raw_input("Enter phone number in the form. (123) 456-7890: \n")
phone=PhoneNumber(newNumber)
print "The phone number is:"
print phone
if__name__=="__main__":
test()
方法__init__接收一個(gè)形如"(xxx) xxx-xxxx"的字符串。字符串中的每個(gè)x都是電話號(hào)碼的一個(gè)位數(shù)。方法對(duì)字符串進(jìn)行分解,并將電話號(hào)碼的不同部分作為屬性存儲(chǔ)。
方法__str__是一個(gè)特殊方法,它構(gòu)造并返回PhoneNumber類的一個(gè)對(duì)象的字符串表示。解析器一旦遇到如下語(yǔ)句:
print phone
就會(huì)執(zhí)行以下語(yǔ)句:
print phone.__str__()
程序如果將PhoneNumber對(duì)象傳給內(nèi)建函數(shù)str(如str(phone)),或者為PhoneNumber對(duì)象使用字符串格式化運(yùn)算符%(例如"%s"%phone),Python也會(huì)調(diào)用__str__方法。
.5__cmp __
比較運(yùn)算符,0:等于 1:大于 -1:小于
class Study:
def __cmp__(self, other):
if other 0 :
return 1
elif other 0:
return - 1
else:
return 0
study = Study()
if study -10:print 'ok1'
if study -10:print 'ok2'
if study == 0:print 'ok3'
打印:ok2 ok3
說(shuō)明:在對(duì)類進(jìn)行比較時(shí),python自動(dòng)調(diào)用__cmp__方法,如-10 0 返回 -1,也就是說(shuō)study 應(yīng)該小與 -10,估打印ok2
.6__getitem__
__getitem__ 專用方法很簡(jiǎn)單。象普通的方法 clear,keys 和 values 一樣,它只是重定向到字典,返回字典的值。
class Zoo:
def __getitem__(self, key):
if key == 'dog':return 'dog'
elif key == 'pig':return 'pig'
elif key == 'wolf':return 'wolf'
else:return 'unknown'
zoo = Zoo()
print zoo['dog']
print zoo['pig']
print zoo['wolf']
打印 dog pig wolf
.7__setitem__
__setitem__ 簡(jiǎn)單地重定向到真正的字典 self.data ,讓它來(lái)進(jìn)行工作。
class Zoo:
def __setitem__(self, key, value):
print 'key=%s,value=%s' % (key, value)
zoo = Zoo()
zoo['a'] = 'a'
zoo['b'] = 'b'
zoo['c'] = 'c'
打印:
key=a,value=a
key=b,value=b
key=c,value=c
.8 __delitem__
__delitem__ 在調(diào)用 del instance[key] 時(shí)調(diào)用 ,你可能記得它作為從字典中刪除單個(gè)元素的方法。當(dāng)你在類實(shí)例中使用 del 時(shí),Python 替你調(diào)用 __delitem__ 專用方法。
class A:
def __delitem__(self, key):
print 'delete item:%s' %key
a = A()
del a['key']
Python正確重載運(yùn)算符的方法示例詳解
說(shuō)到運(yùn)算符重載相信大家都不陌生,運(yùn)算符重載的作用是讓用戶定義的對(duì)象使用中綴運(yùn)算符(如 + 和 |)或一元運(yùn)算符(如 - 和 ~)。說(shuō)得寬泛一些,在 Python 中,函數(shù)調(diào)用(())、屬性訪問(wèn)(.)和元素訪問(wèn) / 切片([])也是運(yùn)算符。
我們?yōu)?Vector 類簡(jiǎn)略實(shí)現(xiàn)了幾個(gè)運(yùn)算符。__add__ 和 __mul__ 方法是為了展示如何使用特殊方法重載運(yùn)算符,不過(guò)有些小問(wèn)題被我們忽視了。此外,我們定義的Vector2d.__eq__ 方法認(rèn)為 Vector(3, 4) == [3, 4] 是真的(True),這可能并不合理。下面來(lái)一起看看詳細(xì)的介紹吧。
運(yùn)算符重載基礎(chǔ)
在某些圈子中,運(yùn)算符重載的名聲并不好。這個(gè)語(yǔ)言特性可能(已經(jīng))被濫用,讓程序員困惑,導(dǎo)致缺陷和意料之外的性能瓶頸。但是,如果使用得當(dāng),API 會(huì)變得好用,代碼會(huì)變得易于閱讀。Python 施加了一些限制,做好了靈活性、可用性和安全性方面的平衡:
不能重載內(nèi)置類型的運(yùn)算符
不能新建運(yùn)算符,只能重載現(xiàn)有的
某些運(yùn)算符不能重載——is、and、or 和 not(不過(guò)位運(yùn)算符
、| 和 ~ 可以)
前面的博文已經(jīng)為 Vector 定義了一個(gè)中綴運(yùn)算符,即 ==,這個(gè)運(yùn)算符由__eq__ 方法支持。我們將改進(jìn) __eq__ 方法的實(shí)現(xiàn),更好地處理不是Vector 實(shí)例的操作數(shù)。然而,在運(yùn)算符重載方面,眾多比較運(yùn)算符(==、!=、、、=、=)是特例,因此我們首先將在 Vector 中重載四個(gè)算術(shù)運(yùn)算符:一元運(yùn)算符 - 和 +,以及中綴運(yùn)算符 + 和 *。
一元運(yùn)算符
-(__neg__)
一元取負(fù)算術(shù)運(yùn)算符。如果 x 是 -2,那么 -x == 2。
+(__pos__)
一元取正算術(shù)運(yùn)算符。通常,x == +x,但也有一些例外。如果好奇,請(qǐng)閱讀“x 和 +x 何時(shí)不相等”附注欄。
~(__invert__)
對(duì)整數(shù)按位取反,定義為 ~x == -(x+1)。如果 x 是 2,那么 ~x== -3。
支持一元運(yùn)算符很簡(jiǎn)單,只需實(shí)現(xiàn)相應(yīng)的特殊方法。這些特殊方法只有一個(gè)參數(shù),self。然后,使用符合所在類的邏輯實(shí)現(xiàn)。不過(guò),要遵守運(yùn)算符的一個(gè)基本規(guī)則:始終返回一個(gè)新對(duì)象。也就是說(shuō),不能修改self,要?jiǎng)?chuàng)建并返回合適類型的新實(shí)例。
對(duì) - 和 + 來(lái)說(shuō),結(jié)果可能是與 self 同屬一類的實(shí)例。多數(shù)時(shí)候,+ 最好返回 self 的副本。abs(...) 的結(jié)果應(yīng)該是一個(gè)標(biāo)量。但是對(duì) ~ 來(lái)說(shuō),很難說(shuō)什么結(jié)果是合理的,因?yàn)榭赡懿皇翘幚碚麛?shù)的位,例如在ORM 中,SQL WHERE 子句應(yīng)該返回反集。
def __abs__(self):
return math.sqrt(sum(x * x for x in self))
def __neg__(self):
return Vector(-x for x in self) #為了計(jì)算 -v,構(gòu)建一個(gè)新 Vector 實(shí)例,把 self 的每個(gè)分量都取反
def __pos__(self):
return Vector(self) #為了計(jì)算 +v,構(gòu)建一個(gè)新 Vector 實(shí)例,傳入 self 的各個(gè)分量
x 和 +x 何時(shí)不相等
每個(gè)人都覺(jué)得 x == +x,而且在 Python 中,幾乎所有情況下都是這樣。但是,我在標(biāo)準(zhǔn)庫(kù)中找到兩例 x != +x 的情況。
第一例與 decimal.Decimal 類有關(guān)。如果 x 是 Decimal 實(shí)例,在算術(shù)運(yùn)算的上下文中創(chuàng)建,然后在不同的上下文中計(jì)算 +x,那么 x!= +x。例如,x 所在的上下文使用某個(gè)精度,而計(jì)算 +x 時(shí),精度變了,例如下面的
沒(méi)有重載,但是可以有默認(rèn)參數(shù)和不定長(zhǎng)參數(shù),可以判斷默認(rèn)值和參數(shù)長(zhǎng)度來(lái)處理。
比如:
def range(start, end = -1):
if end == -1:
end = start
start = 0
或
def range(*args):
if len(args) == 1:
start = 0
end = args[0]
elif len(args) == 2:
start, end = args[0], args[1]
python沒(méi)有大括號(hào),大括號(hào)是C/C++、Java等語(yǔ)言用于標(biāo)記語(yǔ)句塊的語(yǔ)法,Python通過(guò)縮進(jìn)標(biāo)記語(yǔ)句塊,不需要大括號(hào)。
a=1,b=1拆成2條語(yǔ)句,或者寫成a=b=1
F=a+b,b=a,a=F
把上面的語(yǔ)句拆分成三條語(yǔ)句即可。
函數(shù)
Python的函數(shù)支持遞歸、默認(rèn)參數(shù)值、可變參數(shù),但不支持函數(shù)重載。為了增強(qiáng)代碼的可讀性,可以在函數(shù)后書(shū)寫“文檔字符串”(Documentation Strings,或者簡(jiǎn)稱docstrings),用于解釋函數(shù)的作用、參數(shù)的類型與意義、返回值類型與取值范圍等??梢允褂脙?nèi)置函數(shù)help()打印出函數(shù)的使用幫助。
以上內(nèi)容參考:百度百科-Python
python里面沒(méi)有重載吧?
正常的重載說(shuō)的應(yīng)該是函數(shù)方法的重載,即兩個(gè)函數(shù)的名稱相同但是參數(shù)不同是重載,會(huì)出現(xiàn)重載的情況一般是函數(shù)實(shí)現(xiàn)相同功能時(shí),遇到參數(shù)類型可能不同的情況,會(huì)出現(xiàn)重載,如比較常見(jiàn)的對(duì)于加法的實(shí)現(xiàn),如果輸入兩個(gè)整數(shù)相加則直接使用整數(shù)加法,如果兩個(gè)字符串相加則使用字符串的拼接。輸入的參數(shù)類型不同,其實(shí)是兩個(gè)不同的函數(shù),這在那種強(qiáng)類型語(yǔ)言中是可以利用函數(shù)重載來(lái)實(shí)現(xiàn)的,而python中函數(shù)類型是動(dòng)態(tài)的各種各樣的,所以不需要重載這個(gè)機(jī)制。相同函數(shù)名就是表示同一個(gè)方法。
重載和重寫,這是兩個(gè)新概念,是兩個(gè)令我們?nèi)菀谆煜母拍?。方法重載(overloadingmethod)是在一個(gè)類里面,方法名字相同,而參數(shù)不同。返回類型呢?可以相同也可以不同。方法重寫(overidingmethod)子類不想原封不動(dòng)地繼承父類的方法,而是想作一定的修改,這就需要采用方法的重寫。方法重寫又稱方法覆蓋。方法重載是讓類以統(tǒng)一的方式處理不同類型數(shù)據(jù)的一種手段。Java的方法重載,就是在類中可以創(chuàng)建多個(gè)方法,它們具有相同的名字,但具有不同的參數(shù)和不同的定義。調(diào)用方法時(shí)通過(guò)傳遞給它們的不同個(gè)數(shù)和類型的參數(shù)來(lái)決定具體使用哪個(gè)方法,這就是多態(tài)性。方法重寫:在Java中,子類可繼承父類中的方法,而不需要重新編寫相同的方法。但有時(shí)子類并不想原封不動(dòng)地繼承父類的方法,而是想作一定的修改,這就需要采用方法的重寫。方法重寫又稱方法覆蓋。若子類中的方法與父類中的某一方法具有相同的方法名、返回類型和參數(shù)表,則新方法將覆蓋原有的方法。如需父類中原有的方法,可使用super關(guān)鍵字,該關(guān)鍵字引用了當(dāng)前類的父類重寫方法的規(guī)則:參數(shù)列表必須完全與被重寫的方法的相同,否則不能稱其為重寫而是重載.返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載.訪問(wèn)修飾符的限制一定要大于被重寫方法的訪問(wèn)修飾符(publicprotecteddefaultprivate)重寫方法一定不能拋出新的檢查異?;蛘弑缺恢貙懛椒ㄉ昝鞲訉挿旱臋z查型異常.例如,父類的一個(gè)方法申明了一個(gè)檢查異常IOException,在重寫這個(gè)方法是就不能拋出Exception,只能拋出IOException的子類異常,可以拋出非檢查異常.重載的規(guī)則:必須具有不同的參數(shù)列表;可以有不同的返回類型,只要參數(shù)列表不同就可以了;可以有不同的訪問(wèn)修飾符;可以拋出不同的異常;注意,Java的方法重載要求同名的方法必須有不同的參數(shù)表,僅有返回類型不同是不足以區(qū)分兩個(gè)重載的方法。重寫方法只能存在于具有繼承關(guān)系中,重寫方法只能重寫父類非私有的方法。下面分別舉一個(gè)例子來(lái)說(shuō)明方法重載:publicclassTestOverLoad{publicstaticvoidmain(String[]args){Testtest=newTest();test.print(null);}}classTest{publicvoidprint(Stringsome){System.out.println("Stringversionprint");}publicvoidprint(Objectsome){System.out.println("Objectversionprint");}}該程序輸出的結(jié)果是Stringversionprint。