Ich habe einen Datenrahmen wie folgt aus:Wie füge ich eine Spalte zu einem multi-indizierten DataFrame hinzu?
upper level1 level2
lower name name
1 Mary Tom
2 ... ...
Was soll ich tun, wenn ich eine andere Spalte unter level1
hinzufügen? Zum Beispiel
upper level1 level2
lower name age name
1 Mary 13 Tom
2 ... ... ...
kann ich Zugang zu den Daten mit df['level1'].loc[:,'name']
, aber ich weiß nicht, wie eine Spalte hinzufügen/entfernen.
Wenn ich df.level1['age']=1
nur verwenden, gibt Python eine Kopie Warnung und nichts in dem Datenrahmen geändert:
SettingWithCopyWarning:
A value is trying to be set on a copy of a slice from a DataFrame.
Try using .loc[row_indexer,col_indexer] = value instead
See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy
if __name__ == '__main__':
es ist so einfach und elegant! – MaxU
@MaxU Vielen Dank. – piRSquared
Danke, es funktioniert! Könnten Sie bitte erklären, warum mein Code falsch ist? – Arthur