Heim >Backend-Entwicklung >Python-Tutorial >Wie erstelle ich einen Pandas-DataFrame aus einem verschachtelten Wörterbuch mit hierarchischen Indizes?
In diesem Szenario möchten Sie einen Pandas-DataFrame aus einem verschachtelten Wörterbuch erstellen, aus dem die Hierarchie besteht :
Der gewünschte DataFrame sollte Benutzer-IDs als Index und Kategorien und Attribute als Spalten haben.
Ein effizienter Ansatz nutzt den MultiIndex von Pandas, der die Erstellung einer mehrstufigen Indexstruktur ermöglicht. Um diese Methode anzuwenden:
user_dict = {12: {'Category 1': {'att_1': 1, 'att_2': 'whatever'}, 'Category 2': {'att_1': 23, 'att_2': 'another'}}, 15: {'Category 1': {'att_1': 10, 'att_2': 'foo'}, 'Category 2': {'att_1': 30, 'att_2': 'bar'}}} df = pd.DataFrame.from_dict({(i,j): user_dict[i][j] for i in user_dict.keys() for j in user_dict[i].keys()}, orient='index') print(df) att_1 att_2 12 Category 1 1 whatever Category 2 23 another 15 Category 1 10 foo Category 2 30 bar
Alternativ können Sie den DataFrame inkrementell durch Verkettung erstellen:
user_ids = [] frames = [] for user_id, d in user_dict.iteritems(): user_ids.append(user_id) frames.append(pd.DataFrame.from_dict(d, orient='index')) df = pd.concat(frames, keys=user_ids) print(df) att_1 att_2 12 Category 1 1 whatever Category 2 23 another 15 Category 1 10 foo Category 2 30 bar
Das obige ist der detaillierte Inhalt vonWie erstelle ich einen Pandas-DataFrame aus einem verschachtelten Wörterbuch mit hierarchischen Indizes?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!