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]
  • 嗯,测试结果似乎和我们预期的一致。所以,这样就实现对自定义对象的打印。~
  • 以上

参考资料:《Learning Python》

ps: AttrDisplay也是来自于《Learing Python》

你可能感兴趣的:(computer,大猫学python)