python 自定义对象的打印方法
在python中,如果不重写自定义对象的__str__方法,打印出来的对象是一串类似于<__main__.Bean object at 0x1007da470>的字符串。这当然不是我们想要的结果。
于是:通过对__str__方法的重写,就可以返回我们想要的数据的展示。
但是,一个新的问题出现了。以后,如果要修改这个类的属性,那么要想正确的显示对象的属性。还得修改__str__方法。
有没有办法可以做到动态显示所有的属性呢?
当然是有的。
通过对对象的属性的收集,就可以实现动态的打印全部的属性。而且,更方便的是,我们可以将这种方法做成一个工具类。以后,自定义只需要继承该类,就可以实现对象的属性的完成打印了。ps:Python是支持多继承的,所以,继承该类实现格式化打印,并不影响原有逻辑。
看如下代码是如何实现对类属性的动态收集并打印的。
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,似乎所有的工作都已经完成了,来简单测试一下吧:
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]
嗯,测试结果似乎和我们预期的一致。所以,这样就实现对自定义对象的打印。
以上这篇python 自定义对象的打印方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
tf.truncated_normal与tf.random_normal的详细用法
本篇文章主要介绍了tf.truncated_normal与tf.random_normal的详细用法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-03-03python解决No module named pip问题两种方法
当出现No module named pip错误时,表明您的Python环境缺少pip模块,下面这篇文章主要给大家介绍了关于python解决No module named pip问题的两种方法,需要的朋友可以参考下2024-01-01python HTTP协议相关库requests urllib基础学习
这篇文章主要介绍了python HTTP协议相关库requests urllib基础学习,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-06-06
最新评论