python 自定義對象的打印方法
在python中,如果不重寫自定義對象的__str__方法,打印出來的對象是一串類似于<__main__.Bean object at 0x1007da470>的字符串。這當然不是我們想要的結果。
于是:通過對__str__方法的重寫,就可以返回我們想要的數(shù)據(jù)的展示。
但是,一個新的問題出現(xiàn)了。以后,如果要修改這個類的屬性,那么要想正確的顯示對象的屬性。還得修改__str__方法。
有沒有辦法可以做到動態(tài)顯示所有的屬性呢?
當然是有的。
通過對對象的屬性的收集,就可以實現(xiàn)動態(tài)的打印全部的屬性。而且,更方便的是,我們可以將這種方法做成一個工具類。以后,自定義只需要繼承該類,就可以實現(xiàn)對象的屬性的完成打印了。ps:Python是支持多繼承的,所以,繼承該類實現(xiàn)格式化打印,并不影響原有邏輯。
看如下代碼是如何實現(xiàn)對類屬性的動態(tài)收集并打印的。
class AttrDisplay: def gatherAttrs(self): return ",".join("{}={}" .format(k, getattr(self, k)) for k in self.__dict__.keys()) # attrs = [] # for k in self.__dict__.keys(): # item = "{}={}".format(k, getattr(self, k)) # attrs.append(item) # return attrs # for k in self.__dict__.keys(): # attrs.append(str(k) + "=" + str(self.__dict__[k])) # return ",".join(attrs) if len(attrs) else 'no attr' def __str__(self): return "[{}:{}]".format(self.__class__.__name__, self.gatherAttrs())
OK,似乎所有的工作都已經(jīng)完成了,來簡單測試一下吧:
class Bean(AttrDisplay): def __init__(self, id=1024, name='Jack Chen', job='Actor'): self.id = id self.name = name self.job = job def doSomething(self): return self.name + " doing something now ..." if __name__ == '__main__': bob = Bean() print(bob) # [Bean:id=1024,name=Jack Chen,job=Actor]
嗯,測試結果似乎和我們預期的一致。所以,這樣就實現(xiàn)對自定義對象的打印。
以上這篇python 自定義對象的打印方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
tf.truncated_normal與tf.random_normal的詳細用法
本篇文章主要介紹了tf.truncated_normal與tf.random_normal的詳細用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03python解決No?module?named?pip問題兩種方法
當出現(xiàn)No module named pip錯誤時,表明您的Python環(huán)境缺少pip模塊,下面這篇文章主要給大家介紹了關于python解決No?module?named?pip問題的兩種方法,需要的朋友可以參考下2024-01-01使用python 寫一個靜態(tài)服務(實戰(zhàn))
今天小編就為大家分享一篇使用python 寫一個靜態(tài)服務(實戰(zhàn)),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06python?HTTP協(xié)議相關庫requests urllib基礎學習
這篇文章主要介紹了python?HTTP協(xié)議相關庫requests urllib基礎學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06