創建類
Python 類使用 class 關鍵字來創建。簡單的類的聲明可以是關鍵字后緊跟類名:
class ClassName(bases):
??? 'class documentation string' #'類文檔字符串'
??? class_suite #類體
實例化
通過類名后跟一對圓括號實例化一個類
mc = MyClass() # instantiate class 初始化類
‘int()'構造器
def __int__(self):
??? pass
注意:self類似Java的this關鍵字作用,它代碼指向自身實例的引用
類屬性
python的屬性與Java和C++等面向對象語言不同,python的屬性即包括了數據成員還包括函數元素,通過句點符號來訪問.
特殊數據內建屬性
C.
name
類C的名字(字符串)
C.
doc
類C的文檔字符串
C.
bases
類C的所有父類構成的元組
C.
dict
類C的屬性
C.
module
類C定義所在的模塊(1.5 版本新增)
C.
class
實例C對應的類(僅新式類中)
特殊方法內建屬性
dir():獲得類屬性或者實例屬性名字列表.
靜態變量屬性
直接在class作用域定義
class C(object):
??? foo = 100
實例變量屬性
python的實例屬性與Java和C++等不同.在Java和C++中,實例屬性必須首先聲明/定義,而python實例屬性是動態創建。設置實例的屬性可以在實例創建后任意時間進行,也可以在能夠訪問實例的代碼中進行。構造
器init()是設置這些屬性的關鍵點之一。
??? def __init__(self, name, data):
??????? self.name = name
??????? self.data = "123'
注意:self類似Java的this關鍵字作用,它代碼指向自身實例的引用
方法屬性
分為實例方法和類方法.實例方法只屬于一個實例;而類方法即屬于類所有,也屬于實例所有.
實例方法
class MyClass(object):
??? def myNoActionMethod(self):
??? pass
注意:self類似Java的this關鍵字作用,它代碼指向自身實例的引用
靜態方法
靜態方法是類級別的方法,不需要實例化類就可以直接調用.有兩種方法定義
●裝飾器(常用)
??? @staticmethod??
??? def foo():
??????? print 'call static method'
●內建函數
??? def foo():
??????? print 'call static method'
??? foo = staticmethod(foo) #靜態方法
類方法
靜態方法是類級別的方法, 與靜態方法不同的是,它必須顯示傳入cls類參數;而且如果還需要調用類中其他的靜態方法,或者類方法的函數, 要定義成類方法. 與靜態方法類似,也有兩種方法定義.
●裝飾器(常用)
??? @classmethod???
??? def bar(cls):
??????? print 'call class method and access static varible(staticVar): ', cls.staticVar
●內建函數
def bar(cls):
??????? print 'call class method and access static varible(staticVar): ', cls.staticVar
??? bar = classmethod(bar)? #類方法
實例詳解
#!/usr/bin/python
#coding=utf-8
class Target(): #定義類Target
??? 'This is Target definition' #定義__doc__屬性
??? staticVar = 'v1.0'? #定義靜態變量
??? def __init__(self, name = 'default', data = 0): #定義構造函數
??????? self.name = name??? #實例變量
??????? self.data = data??? #實例變量
??????? print "init instance"
??? def main():
??????? print "this is a test function"
??? '''
??? 可以用裝飾器定義靜態方法
??? @staticmethod??
??? def foo():
??????? print 'call static method'
??? '''
??? def foo():
??????? print 'call static method'
??? foo = staticmethod(foo) #靜態方法
??? '''
??? 可以用裝飾器定義類方法
??? @classmethod???
??? def bar(cls):
??????? print 'call class method and access static varible(staticVar): ', cls.staticVar
??? '''
??? def bar(cls):
??????? print 'call class method and access static varible(staticVar): ', cls.staticVar
??? bar = classmethod(bar)? #類方法
??? #只有調用本模塊的時候main()方法才生效
??? if __name__ == '__main__':
??????? main()
#實例化
target = Target('aaa', 123)
print 'name is: ', target.name
print 'data is: ', target.data
#打印__doc__屬性
print 'target.__doc__ is: ', target.__doc__
#打印類__dict__屬性
print 'Target.__dict__ is: ', Target.__dict__
#打印靜態變量
print 'staticVar is: ', Target.staticVar
#打印內建函數dir()
print 'dir() is: ', dir(Target)
#調用靜態方法
Target.foo()
#調用類方法
Target.bar()
輸出
this is a test function
init instance
name is:? aaa
data is:? 123
target.__doc__ is:? This is Target definition
Target.__dict__ is:? {'__module__': '__main__', 'foo':
staticVar is:? v1.0
dir() is:? ['__doc__', '__init__', '__module__', 'bar', 'foo', 'main', 'staticVar']
call static method
call class method and access static varible(staticVar):? v1.0
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
