Sulla @ Godsmith di train of thought e affrontare @ necessità di Zitrax (credo) a fare la copia dei dati per tutti gli attributi all'interno del costruttore:
class ConfusionMatrix(pd.DataFrame):
def __init__(self, df, *args, **kwargs):
try:
# Check if `df` looks like a `ConfusionMatrix`
# Could check `isinstance(df, ConfusionMatrix)`
# But might miss some "ConfusionMatrix-elligible" `DataFrame`s
assert((df.columns == df.index).all())
assert(df.values.dtype == int)
self.construct_copy(df, *args, **kwargs)
return
except (AssertionError, AttributeError, ValueError):
pass
# df is just data, so continue with normal constructor here ...
def construct_copy(self, other, *args, **kwargs):
# construct a parent DataFrame instance
parent_type = super(ConfusionMatrix, self)
parent_type.__init__(other)
for k, v in other.__dict__.iteritems():
if hasattr(parent_type, k) and hasattr(self, k) and getattr(parent_type, k) == getattr(self, k):
continue
setattr(self, k, deepcopy(v))
Questa classe ConfusionMatrix
eredita un pandas.DataFrame
e aggiunge una tonnellata di altri attribut es e metodi che devono essere ricalcolati a meno che non sia possibile copiare i dati della matrice other
. Alla ricerca di una soluzione è come ho trovato questa domanda.
Potreste essere interessati a questa domanda [Disclaimer: è stato colui che lo ha chiesto]: http://stackoverflow.com/questions/990758/reclassing-an-instance-in-python – balpha
Fai attenzione. Gli avvertimenti inviati da alcuni dei rispondenti non devono essere sottovalutati. – balpha
Non sembra molto leggibile, probabilmente sto cambiando il mio codice dall'utilizzo dell'ereditarietà per incapsulare semplicemente l'altro oggetto. – Zitrax