自动__repr__方法

app*_*orm 16 python

我希望有任何类的简单表示,比如{ property = value },是否有自动__repr__

Shu*_*ary 14

最简单的方法:

def __repr__(self):
    return str(self.__dict__)
Run Code Online (Sandbox Code Playgroud)


Ste*_*202 9

是的,您可以创建一个类"AutoRepr"并让所有其他类扩展它:

>>> class AutoRepr(object):
...     def __repr__(self):
...         items = ("%s = %r" % (k, v) for k, v in self.__dict__.items())
...         return "<%s: {%s}>" % (self.__class__.__name__, ', '.join(items))
... 
>>> class AnyOtherClass(AutoRepr):
...     def __init__(self):
...         self.foo = 'foo'
...         self.bar = 'bar'
...
>>> repr(AnyOtherClass())
"<AnyOtherClass: {foo = 'foo', bar = 'bar'}>"
Run Code Online (Sandbox Code Playgroud)

请注意,上述代码不能很好地处理(直接或间接)引用自身的数据结构.作为替代方案,您可以定义适用于任何类型的函数:

>>> def autoRepr(obj):
...     try:
...         items = ("%s = %r" % (k, v) for k, v in obj.__dict__.items())
...         return "<%s: {%s}." % (obj.__class__.__name__, ', '.join(items))
...     except AttributeError:
...         return repr(obj)
... 
>>> class AnyOtherClass(object):
...     def __init__(self):
...         self.foo = 'foo'
...         self.bar = 'bar'
...
>>> autoRepr(AnyOtherClass())
"<AnyOtherClass: {foo = 'foo', bar = 'bar'}>"
>>> autoRepr(7)
'7'
>>> autoRepr(None)
'None'
Run Code Online (Sandbox Code Playgroud)

注意,由于前面提到的原因,上述函数没有故意递归定义.


vod*_*dan 6

好吧,我玩了一些其他答案并得到了一个非常漂亮的解决方案:

class data:
    @staticmethod
    def repr(obj):
        items = []
        for prop, value in obj.__dict__.items():
            try:
                item = "%s = %r" % (prop, value)
                assert len(item) < 20
            except:
                item = "%s: <%s>" % (prop, value.__class__.__name__)
            items.append(item)

        return "%s(%s)" % (obj.__class__.__name__, ', '.join(items))

    def __init__(self, cls):
        cls.__repr__ = data.repr
        self.cls = cls

    def __call__(self, *args, **kwargs):
        return self.cls(*args, **kwargs)
Run Code Online (Sandbox Code Playgroud)

您将其用作装饰器:

@data
class PythonBean:
    def __init__(self):
        self.int = 1
        self.list = [5, 6, 7]
        self.str = "hello"
        self.obj = SomeOtherClass()
Run Code Online (Sandbox Code Playgroud)

__repr__开箱即用:

PythonBean(int = 1, obj: <SomeOtherClass>, list = [5, 6, 7], str = 'hello')
Run Code Online (Sandbox Code Playgroud)

这适用于任何递归类,包括树结构。如果您尝试在 class 中放置一个自引用self.ref = self,该函数将尝试(成功)解决它大约一秒钟。

当然,永远注意你的老板 - 我的不喜欢这样的语法糖))