Я пытаюсь использовать composition с pandas.DataFrame следующим образом, но при попытке скопировать объект возникают ошибки.
import numpy as np
import pandas as pd
import copy
class Foo(object):
"""
Foo is composed mostly of a pd.DataFrame, and behaves like it too.
"""
def __init__(self, df, attr_custom):
self._ = df
self.attr_custom = attr_custom
# the following code allows Foo objects to behave like pd.DataFame,
# and I want to keep this behavior.
def __getattr__(self, attr):
return getattr(self._, attr)
df = pd.DataFrame(np.random.randint(0,2,(3,2)), columns=['A','B'])
foo = Foo(df)
foo_cp = copy.deepcopy(foo)
Ошибка, которую я получаю:
---> 16 foo_cp = copy.deepcopy(foo)
/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/copy.pyc in deepcopy(x, memo, _nil)
188 raise Error(
189 "un(deep)copyable object of type %s" % cls)
--> 190 y = _reconstruct(x, rv, 1, memo)
191
192 memo[d] = y
/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/copy.pyc in _reconstruct(x, info, deep, memo)
341 slotstate = None
342 if state is not None:
--> 343 y.__dict__.update(state)
344 if slotstate is not None:
345 for key, value in slotstate.iteritems():
TypeError: 'BlockManager' object is not iterable
Мои вопросы:
- Любая идея, что здесь происходит?
- Каков «рекомендуемый» способ использования композиции с pandas.DataFrame?
- Если по каким-то причинам использование
_
в качестве имени фиктивного атрибута является плохой идеей, сообщите мне об этом.