生活随笔
收集整理的這篇文章主要介紹了
面向对象高级
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
面向對象高級
isinstance(obj,cls)和issubclass
isinstance(obj,cls)檢查obj是否是類cls的對象issubclass(sub,super)檢查sub類是否是super類的派生類
python中面向對象中的反射:通過字符串的形式操作對象相關的屬性。python中的一切事物都是對象(都可以用反射)。
hasattr(object,name)# 判斷object中有沒有name的屬性或者方法
getattr(object,name,default = None)# object: 對象# name: 字符串,屬性# default: 默認返回值,如果不提供該參數,在沒有對應屬性時,觸發AttributeError
setattr(object,name,value)# object: 對象# name: 字符串,屬性# value: 屬性值# 對已存在的屬性進行修改,如果沒有,則會新建出這個屬性
delattr(object,name)# object: 對象# name: 屬性(必須是屬性,不能是方法)# detattr(x,'foobar') == del x.foobar
__dict__ :類的屬性(包含一個字典,由類的數據屬性組成)__doc__: 類的文檔字符串__name__: 類名__module__:類定義所在的模塊(類的全名是'__main__.className',如果類位于一個導入模塊common_module中,那么className.__module__ 等于common_module)
打印內容如下:
# 把一個類的實例變成strclass Person(object):self.name = nameself.gender = genderdef __str__(self):return '(Person:%s,%s)'%(self.name,self.gender)
def __setattr__(self,name,value):pass# 添加/修改屬性時,會觸發執行
def __getattr__(self,item):pass# 只有在調用屬性,且屬性不存在時,才會觸發
def __delattr__(self,item):pass# 刪除屬性時會觸發
轉載于:https://www.cnblogs.com/oden/p/10426861.html
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀
總結
以上是生活随笔為你收集整理的面向对象高级的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。