0 前言
系統:win7 64bit
IDE : python(x,y) 2.7.6.1
IDE集成的解釋器:Python 2.7.6 (default, Nov 10 2013, 19:24:18) [MSC v.1500 32 bit (Intel)] on win32
1 單繼承
1.1 定義一個時間類,帶默認參數
class mytime(object): def __init__(self,hour=21, \ minute=13, \ second=50): self.hour = hour self.minute = minute self.second = second def __str__(self): return '__str__ hour:minute:second = %02d:%02d:%02d' \ %(self.hour,self.minute,self.second) def get_hour(self): return self.hour def get_minute(self): return self.minute def get_second(self): return self.second def print_time(self): print 'hour:minute:second = %02d:%02d:%02d' %(self.hour,self.minute,self.second)
說明: 構造函數 __init__(self,hour=21, minute=13, second=50) 帶默認參數的定義方式 ;
用於輸出的函數 __str__
得到某屬性值的方法 get_xxxx
輸出屬性值的方法 print_time
1.2 定義日期時間類,繼承時間類的屬性和方法
class mydatetime(mytime):
def __init__(self,year = 2016,mounth = 1,day = 1, \
hour=21, minute=13,second=50):
super(mydatetime,self).__init__(hour,minute,second)
self.year = year
self.mounth = mounth
self.day = day
def __str__(self):
return '__str__ year--mounth--day = %02d--%02d--%02d' \
%(self.year,self.mounth,self.day)
def __del__(self):
""" __del__ mydatetime destroyed """
print "__del__ mydatetime destroyed"
def print_date(self):
print 'year-mounth-day = %04d-%02d-%02d' \
%(self.year,self.mounth,self.day)
# self.print_time()
說明: mydatetime 繼承 mytime 的屬性值,這里mydatetime(子類),mytime(父類)
構造函數 __init__(self,year = 2016,mounth = 1,day = 1, hour=21, minute=13,second=50) 帶默認參數的定義方式 ,注意要通過 super初始化父類屬性值;
用於輸出的函數 __str__
輸出屬性值的方法 print_date
1.3 測試
if __name__ == '__main__':
print "\n"
print "--"*10," mytime t0:"
t0 = mytime()
print t0
t0.print_time()
print t0.get_hour()
print "\n"
print "--"*10," mytime t1:"
t1 = mytime(hour=7,second=20)
t1.print_time()
print "\n"
print "--"*10," mydatetime da:"
da = mydatetime(minute=40)
print da
# da.print_date()
da.print_time()
del da
輸出:
>>> runfile('F:/Python/hysrc_py/untitled0_class.py', wdir=r'F:/Python/hysrc_py')
-------------------- mytime t0:
__str__ hour:minute:second = 21:13:50
hour:minute:second = 21:13:50
21
-------------------- mytime t1:
hour:minute:second = 07:13:20
-------------------- mydatetime da:
__str__ year--mounth--day = 2016--01--01
hour:minute:second = 21:40:50
__del__ mydatetime destroyed
>>>
2 多重繼承
2.1 定義父類 classA classX
class classA(object):
def __init__(self):
print('init action in father class A')
class classX(object):
def __init__(self):
print('init action in father class X')
2.2 SubClassB 繼承 classA
class SubClassB(classA):
def __init__(self):
print('init action in subclass B')
super(SubClassB,self).__init__()
2.3 SubClassC 繼承 SubClassB
class SubClassC(SubClassB):
def __init__(self):
print('init action in subclass C')
super(SubClassC,self).__init__()
2.4 測試
實例化一個SubClassC類
if __name__ == '__main__':
print "\n"
print "--"*10," SubClassC b:"
b = SubClassC()
由輸出可知:多重繼承時,子類會自動調用父類的構造函數
-------------------- SubClassC b: init action in subclass C init action in subclass B init action in father class A
3 多重繼承
3.1 定義兩個基本類 classA 和 classX
class classA(object):
def __init__(self,a='classA'):
self.a = a
print('init action in father class A')
def print_a(self):
print self.a
class classX(object):
def __init__(self,x='classX'):
self.x = x
print('init action in father class X')
def print_x(self):
print self.x
3.2 SubClassX 類繼承自 classA 和 classX
class SubClassX(classA,classX):
def __init__(self,a='SubClassX:a',x='SubClassX:x'):
print('init action in subclass X')
super(SubClassX,self).__init__()
# classX.__init__(self)
self.a = a
self.x = x
def print_SubX(self):
self.print_a()
self.print_x()
3.3 實例化一個 SubClassX 類
if __name__ == '__main__':
print "\n"
print "--"*10," SubClassX x:"
sx = SubClassX()
sx.print_SubX()
3.4 由輸出可知 : SubClassX 繼承了 classA 和 classX 的方法和屬性,但不知為何只調用了 classA的初始化函數?
-------------------- SubClassX x: init action in subclass X init action in father class A SubClassX:a SubClassX:x
3.5 分析:其實在 3.4 的輸出可知,SubClassX只調用了classA的初始化,則classX的屬性是不會自動初始化的,如classX的屬性值x,之所以能夠輸出 "SubClassX:x" ,是由於在 3.2的定義中,手動初試化了 屬性值。self.a = a self.x = x
如下例:
class SubClassX(classA,classX):
def __init__(self,a='SubClassX:a',x='SubClassX:x'):
print('init action in subclass X')
super(SubClassX,self).__init__(a)
# classX.__init__(self)
# self.x = x
def print_SubX(self):
self.print_a()
self.print_x()
實例化一個 SubClassX 類:
if __name__ == '__main__':
print "\n"
print "--"*10," SubClassX x:"
sx = SubClassX()
sx.print_SubX()
輸出報錯: 由於定義SubClassX類時,使用 super 初始化父類,只會初試化 classA,即第一個類。而classX排在了classA之后,不會自動初始化。所以在實例化類調用方法時,即 sx.print_SubX() 。由於沒有屬性 'x' 而報錯。
-------------------- SubClassX x:
init action in subclass X
init action in father class A
SubClassX:a
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\Python27\lib\site-packages\spyderlib\widgets\externalshell\sitecustomize.py", line 540, in runfile
execfile(filename, namespace)
File "F:/Python/hysrc_py/untitled0_class.py", line 111, in <module>
sx.print_SubX()
File "F:/Python/hysrc_py/untitled0_class.py", line 57, in print_SubX
self.print_x()
File "F:/Python/hysrc_py/untitled0_class.py", line 24, in print_x
print self.x
AttributeError: 'SubClassX' object has no attribute 'x'
>>>
錯誤提示:屬性錯誤:'SubClassX' 對象 沒有屬性 'x'
