Heim > Backend-Entwicklung > Python-Tutorial > Wie explodiere ich Listen in Pandas DataFrames?

Wie explodiere ich Listen in Pandas DataFrames?

Linda Hamilton
Freigeben: 2024-12-03 11:45:12
Original
403 Leute haben es durchsucht

How to Explode Lists Within Pandas DataFrames?

Explodierende Listen in Pandas

Problemstellung

In Pandas Sie kann auf Datenrahmen mit Zellen stoßen, die Listen mit mehreren Werten enthalten. Anstatt mehrere Werte in einer einzelnen Zelle zu speichern, kann es von Vorteil sein, den Datenrahmen zu erweitern, sodass jedes Element in der Liste eine eigene Zeile einnimmt.

Lösung für Pandas >= 0,25

Pandas Version 0.25 und höher führt die .explode() ein Methode für Series und DataFrame. Diese Methode trennt Listenelemente effektiv in verschiedene Zeilen.

Um eine Spalte aufzulösen, verwenden Sie einfach die folgende Syntax:

df.explode('column_name')
Nach dem Login kopieren

Betrachten wir beispielsweise den folgenden Datenrahmen:

import pandas as pd
import numpy as np

df = pd.DataFrame(
    {'trial_num': [1, 2, 3, 1, 2, 3],
     'subject': [1, 1, 1, 2, 2, 2],
     'samples': [list(np.random.randn(3).round(2)) for i in range(6)]
    }
)
Nach dem Login kopieren

Um die Spalte „Beispiele“ aufzulösen, würden wir Folgendes verwenden:

df_exploded = df.explode('samples')
Nach dem Login kopieren

Dies würde das Gewünschte ergeben Ausgabe:

   subject  trial_num  samples
0        1          1    0.57
1        1          1   -0.83
2        1          1    1.44
3        1          2   -0.01
4        1          2    1.13
5        1          2    0.36
6        1          3    1.18
# etc.
Nach dem Login kopieren

Hinweis für gemischte Spalten

Die Methode .explode() kann gemischte Spalten aus Listen und Skalaren verarbeiten. sowie leere Listen und NaNs. Es ist jedoch wichtig zu beachten, dass es jeweils nur eine einzelne Spalte auflösen kann.

Das obige ist der detaillierte Inhalt vonWie explodiere ich Listen in Pandas DataFrames?. 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