Heim > Backend-Entwicklung > Python-Tutorial > 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
Freigeben: 2024-11-02 08:50:29
Original
809 Leute haben es durchsucht

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']
Nach dem Login kopieren

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']
Nach dem Login kopieren

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

    A  B
0  12  NaN
1  23  ['foo', 'bar']
Nach dem Login kopieren

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')
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage