1

我有一个来自 numpy.ndarray 的子类,它修改了按索引获取项目的行为。但是,当有人在我的子类上打印时,我想保留原始的 ndarray 输出格式。我尝试覆盖 __iter__ 函数,但似乎不起作用。鉴于 __getitem__ 已重载,是否可以按底层数组顺序打印输出数字?

import numpy as np

class imarray(np.ndarray):
    def __new__(cls, d, f):
        nd = np.asarray(d)
        return super(imarray, cls).__new__(cls,(nd.size,), dtype=nd.dtype, buffer=nd).view(imarray)
    def __init__(self, d, f):
        self.f = f
    def __array_finalize__(self, o):
        pass
    def __getitem__(self, i):
        return super(imarray, self).__getitem__(self.f(i))
    def __setitem__(self, i, y):
        return super(imarray, self).__setitem__(self.f(i), y)
    def __iter__(self):
        return super(imarray, self).__iter__

if __name__ == "__main__":
    a = imarray([1., 2., 3.1415], lambda i:i+1)
    print a[0] # print .2
    a[-1] =.4
    print a[-1] # print .4
    print a # print [ 2. 3.1415 0.4 ] but want [ 0.4 2. 3.1415 ]
4

2 回答 2

2

打印返回对象__str__方法。

所以你需要 ovveride __str__

>>> class ex():
    def __init__(self, value):
        self.val = value
    def __str__(self):
        return self.val * 2


>>> a = ex('A')
>>> print a
AA
于 2013-03-05T09:38:32.357 回答
1

这实际上取决于。

如果您打印一个对象,print将调用它的__str__方法。

但是,如果您打印一个list(或setdict),print将调用列表的__str__方法,该方法又将调用项目的__repr__方法。这很奇怪,但很容易观察到:

>>> class B():
...     def __repr__(self): return '__repr__'
...     def __str__(self): return '__str__'
...
>>> print B()
__str__
>>> print [B()]
[__repr__]
>>> print set([B()])
set([__repr__])
>>> print {B(): B()}
{__repr__: __repr__}
于 2013-03-05T09:50:33.737 回答