Heim  >  Artikel  >  Backend-Entwicklung  >  Wie füge ich Listen ohne Fehler in Pandas DataFrame-Zellen ein?

Wie füge ich Listen ohne Fehler in Pandas DataFrame-Zellen ein?

Linda Hamilton
Linda HamiltonOriginal
2024-11-02 08:50:29677Durchsuche

How to Insert Lists into Pandas DataFrame Cells Without Errors?

Einfügen von Listen in Pandas-Zellen

Problem

In Python kann der Versuch, eine Liste in eine Zelle eines Pandas-DataFrames einzufügen, zu Fehlern führen oder unerwartete Ergebnisse. Wenn Sie beispielsweise versuchen, eine Liste in Zelle 1B eines DataFrame df einzufügen:

df = pd.DataFrame({'A': [12, 23], 'B': [np.nan, np.nan]})
abc = ['foo', 'bar']

Die folgenden Versuche, die abc-Liste in 1B einzufügen, führen jedoch zu Fehlern oder falschen Einfügungen:

  1. df.ix[1,'B'] = abc – Fehler: Beim Festlegen mit einem iterierbaren Wert müssen gleiche Len-Schlüssel und -Werte vorhanden sein
  2. df.ix[1,'B'] = [abc ] – Fügt eine Liste mit einem Element ein: [['foo', 'bar']]
  3. df.ix[1,'B'] = ', '.join(abc) – Fügt eine Zeichenfolge ein: "foo, bar"
  4. df.ix[1,'B'] = [', '.join(abc)] – Fügt eine Liste mit einem Element ein: ['foo, bar']

Lösung

Um Listen fehlerfrei in Zellen eines DataFrame einzufügen, verwenden Sie die at-Methode, die sich immer auf einen einzelnen Wert bezieht:

df.at[1, 'B'] = ['foo', 'bar']

Dadurch wird der eingefügt abc-Liste wie erwartet in 1B einfügen:

    A  B
0  12  NaN
1  23  ['foo', 'bar']

Beachten Sie, dass die DataFrame-Spalte dtype=object haben muss, um das Einfügen der Liste zu ermöglichen. Zum Beispiel:

df['B'] = df['B'].astype('object')

Das obige ist der detaillierte Inhalt vonWie füge ich Listen ohne Fehler in Pandas DataFrame-Zellen ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn