1.1 class
用法
instance.__class__
描述
獲取實例所屬類。為實例屬性。
示例
>>> class MyClass:pass
>>> c1=MyClass()
>>> c1
<__main__.MyClass object at 0x03D19C50>
# __class__ 返回實例所屬類
>>> c1.__class__
# 用返回的類創建實例對象
>>> c2=c1.__class__()
>>> c2
<__main__.MyClass object at 0x03D19CF0>
1.2 class.name
用法
instance.__class__.__name__
描述
獲取實例所屬類的名字。返回字符串。
示例
>>> class MyClass:pass
>>> c1=MyClass()
>>> c1=MyClass()
# __name__ 返回實例所屬類的名字
>>> c1.__class__.__name__
'MyClass'
1.3 bases
用法
類.__bases__
描述
返回該類的直接超類組成的元組
示例
>>> class MyClass:pass
>>> class MyClassA(MyClass):pass
>>> class MyClassB():pass
# __bases__ 返回直接超類組成的元組
>>> MyClassC.__bases__
(, )
1.4 dict
類和實例的屬性字典。
實例無本身屬性則為空。
>>> class MyClass:
s='梯閱線條'
def f1(self):pass
>>> c1=MyClass()
# __dict__ 查看類的屬性字典,
# 前后帶雙下劃線的為內置屬性 , 其他為自定義屬性
>>> MyClass.__dict__.keys()
dict_keys(['__module__', 's', 'f1', '__dict__', '__weakref__', '__doc__'])
>>> c1.__dict__.keys()
dict_keys([])
>>> c1.a=9555
>>> c1.__dict__.keys()
dict_keys(['a'])
>>> c1.s='tyxt'
# __dict__ 查看實例的屬性字典,
# 只返回實例賦值的屬性,不返回類的屬性
>>> c1.__dict__.keys()
dict_keys(['a', 's'])
>>> MyClass.__dict__.keys()
dict_keys(['__module__', 's', 'f1', '__dict__', '__weakref__', '__doc__'])
1.5 _X
python類內定義的_X:
(1)單下劃線開頭的變量名,_X通常在工具類中用于避免與子類的命名沖突。
比如,子類繼承了一個工具類,然后定義了一個同名變量,那么會取到子類的變量,而實際想使用工具類里面的變量。此時,在工具類通過單下劃下命名變量,可以很大程度上避免沖突。
(2)_X一般只在類內調用,不在類外調用。
1.6 __X
python類內定義的__X
(1) 雙下劃線開頭的變量名,__X為偽私有類屬性。
(2) 自動在*_X前面加“*類名”。
示例
>>> class MyClass:
def me1(self):pass
def _me2(self):pass
def __me3(self):pass
>>> [x for x in dir(MyClass) if not x.endswith('__')]
['_MyClass__me3', '_me2', 'me1']
1.7 getattr()
用法
getattr(object, name[, default])
描述
返回對象的屬性值。
obejct:對象(類對象或實例對象)
name:屬性名的字符串
default:不存在屬性時返回的默認值,不存在屬性未給默認值則報錯
示例
>>> class MyClass:
s='梯閱線條'
def f1(self):
print('f1')
# getattr 第一個參數為 對象 object
# 第二個參數為 字符串屬性名
# 返回數據屬性值
>>> getattr(MyClass,'s')
'梯閱線條'
# 返回行為屬性值
>>> getattr(MyClass,'f1')
1.8 示例-優化顯示
通過內省工具getattr()和 class .name 動態顯示屬性值。
文件
myclasstools.py
class ShowAttr:
def collectAttrs(self):
attrs = []
for k in sorted(self.__dict__):
attrs.append('{}={}'.format(k,getattr(self,k)))
return ','.join(attrs)
def __str__(self):
return '{}:{}'.format(self.__class__.__name__,self.collectAttrs())
myperson.py
from myclasstools import ShowAttr
class MyPerson(ShowAttr):
def __init__(self,name,job = None,pay = 0):
self.name = name
self.job = job
self.pay = pay
def payraise(self,rate):
self.pay = int(self.pay * (1 + rate))
#def __str__(self):
#return 'MyPerson:name={0.name},job={0.job},pay={0.pay}'.format(self)
class MyManager(MyPerson):
def __init__(self,name,job = 'mgr',pay = 0):
MyPerson.__init__(self,name,job,pay)
def payraise(self,rate,bonus=0.1):
MyPerson.payraise(self,rate+bonus)
if __name__ == '__main__':
mp1 = MyPerson('mp1')
mp2 = MyPerson('mp2','c++開發',20000)
mm1 = MyManager('mm1','開發經理',50000)
print(mp1)
print(mp2)
print(mm1)
mp2.payraise(0.1)
mm1.payraise(0.1)
print(mp2)
print(mm1)
執行
E:\\documents\\F盤>python myperson.py
MyPerson:job=None,name=mp1,pay=0
MyPerson:job=c++開發,name=mp2,pay=20000
MyManager:job=開發經理,name=mm1,pay=50000
MyPerson:job=c++開發,name=mp2,pay=22000
MyManager:job=開發經理,name=mm1,pay=60000
-
編程
+關注
關注
88文章
3677瀏覽量
94799 -
python
+關注
關注
56文章
4823瀏覽量
86041
發布評論請先 登錄
使用Rust優化Python性能

評論