Python 關於反射和類的特殊成員方法

來源:互聯網
上載者:User
本文給大家分享python關於反射和類的特殊成員方法,非常不錯,具有參考借鑒價值,需要的朋友參考下吧

反射

反射即想到4個內建函數分別為:getattr、hasattr、setattr、delattr 擷取成員、檢查成員、設定成員、刪除成員


class Dog(object):  def __init__(self,name):    self.name = name  def eat(self):    print("%s is eating..."%self.name)def run():  print("runing ....")d = Dog("lucy")choise=input("請輸入要調用的方法:")if hasattr(d,choise):#判斷一個對象是否有對應的字串方法  func=getattr(d,choise)#根據字串去擷取對象裡相應的方法或屬性的記憶體位址對象  func()else:  setattr(d,choise,run)#setattr(obj,y,fun)相當於obj.y=fun,fun可以是屬性或者方法  v=getattr(d,choise)  print(v)

dir([obj]):

調用這個方法將返回包含obj大多數屬性名稱的列表(會有一些特殊的屬性不包含在內)。obj的預設值是當前的模組對象。

hasattr(obj, attr):

這個方法用於檢查obj是否有一個名為attr的值的屬性,返回一個布爾值。

getattr(obj, attr):

調用這個方法將返回obj中名為attr值的屬性的值,例如如果attr為'bar',則返回obj.bar。

setattr(obj, attr, val):

調用這個方法將給obj的名為attr的值的屬性賦值為val。例如如果attr為'bar',則相當於obj.bar = val。

__doc__ 查看尖的描述資訊
__module__表示當前操作的對象所在的模組
__class__表示當前操作的對象所屬的類
__init__構造方法 通過類建立對象自動執行
__del__析構方法,當前對象在記憶體中被釋放自動斬妖執行
__call__對象後面加括弧觸發執行
__dict__查看類或對象中的成員
__str__如果一個類中定義了此方法,那麼列印此類對象時,輸出此方法的傳回值
__getitem__當類中定義了一個字典的屬性成員,可以擷取
__setitem__設定修改類中字典的資料
__delitem__刪除 類中字典的資料
__metalass__其用來表示該類由 誰 來執行個體化建立
__new__觸發 __init__建立執行個體


from lib.ss import a#樣本類 dogclass doges(object):  """類的描述資訊"""  def __init__(self,name,food):    self.name=name    self.food=food    self.data={}#定義一個類的字典  def __call__(self, *args, **kwargs):#對象後面加括弧解執行    print(*args)  def __str__(self):#預設輸出傳回值    return self.name  def __getitem__(self):#可以擷取類的的字典    return self.data  def __setitem__(self, key, value):#可以設定類的的字典    self.data[key]=value  def __delitem__(self, key):#可以刪除類的字典的內容    del self.data[key]dog=doges('xxx','iii')print(dog.__doc__)b=a()print(b.__module__)#操作的對象的那個模組print(dog.__class__)#當前操作的對象的類是什麼dog('111')#print(doges.__dict__)#查看類或對象的成員 類只列印類的成員不列印對象的成員print(dog.__dict__)#查看類或對象的成員 對象只列印對象的成員不列印類的成員print(dog)#列印 __str__的傳回值print(dog.__str__())#列印傳回值dog['1']=1000#觸發.__setitem__()dog['2']=1000#觸發.__setitem__()print(dog.__getitem__())print(dog.__delitem__('1'))#刪除類中字典print(dog.__getitem__())#設定類的特殊方法def func(self):  print('hello word%s'%self.name)  print()def __init__(self,name,age):  self.name=name  self.age=age##type參數 1:類名 2.類的基類 3.類的成員,字典格式CAT=type('CAT',(object,),{'func':func,'__init__':__init__})cat=CAT('喵喵',3)cat.func()print(cat.name,cat.age)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.