Heim > Backend-Entwicklung > Python-Tutorial > Wie extrahiere ich effizient Zeilen aus einem Pandas-DataFrame, die in einem anderen fehlen?

Wie extrahiere ich effizient Zeilen aus einem Pandas-DataFrame, die in einem anderen fehlen?

Susan Sarandon
Freigeben: 2024-12-06 18:44:12
Original
714 Leute haben es durchsucht

How to Efficiently Extract Rows from One Pandas DataFrame that are Absent in Another?

Abrufen von Zeilen aus einem Datenrahmen, die von einem anderen ausgeschlossen sind

In Pandas ist es üblich, mehrere Datenrahmen mit potenziell überlappenden Daten zu haben. Eine häufig auftretende Aufgabe besteht darin, Zeilen aus einem Datenrahmen zu isolieren, die in einem anderen nicht vorhanden sind. Dieser Vorgang ist besonders nützlich, wenn Sie mit Teilmengen arbeiten oder Daten filtern.

Problemformulierung:

Gegeben zwei Pandas-Datenrahmen, wobei df1 im Vergleich zu df2 eine Obermenge von Zeilen enthält, Unser Ziel ist es, die Zeilen in df1 zu erhalten, die in df2 nicht gefunden werden. Das folgende Beispiel veranschaulicht dieses Szenario anhand eines einfachen Falls:

import pandas as pd

df1 = pd.DataFrame(data={'col1': [1, 2, 3, 4, 5], 'col2': [10, 11, 12, 13, 14]})
df2 = pd.DataFrame(data={'col1': [1, 2, 3], 'col2': [10, 11, 12]})

print(df1)
print(df2)

# Expected result:
#   col1  col2
# 3     4    13
# 4     5    14
Nach dem Login kopieren

Lösung:

Um dieses Problem effektiv anzugehen, verwenden wir eine Technik, die als Left Join bekannt ist. Dieser Vorgang führt df1 und df2 zusammen und stellt gleichzeitig sicher, dass alle Zeilen von df1 beibehalten werden. Darüber hinaus fügen wir eine Indikatorspalte ein, um den Ursprung jeder Zeile nach der Zusammenführung zu identifizieren. Indem wir die eindeutigen Zeilen von df2 nutzen und Duplikate ausschließen, erreichen wir das gewünschte Ergebnis.

Der folgende Python-Code implementiert diese Lösung:

df_all = df1.merge(df2.drop_duplicates(), on=['col1', 'col2'], how='left', indicator=True)
result = df_all[df_all['_merge'] == 'left_only']
Nach dem Login kopieren

Erklärung:

  1. Left Join: Die Merge-Funktion führt einen Left Join zwischen durch df1 und df2.drop_duplicates(). Dieser Vorgang führt Zeilen von df1 mit Zeilen von df2 zusammen, basierend auf den übereinstimmenden Werten in den Spalten col1 und col2.
  2. Merge-Indikator: Der Indikatorparameter ist auf True gesetzt, um eine zusätzliche Spalte mit dem Namen _merge einzuschließen im resultierenden Datenrahmen df_all. Diese Spalte gibt den Ursprung jeder Zeile an: „both“ für Zeilen, die sowohl in df1 als auch in df2 vorhanden sind, „left_only“ für Zeilen exklusiv für df1 und „right_only“ für Zeilen exklusiv für df2.
  3. Filtern nach „left_only“: Um Zeilen aus df1 zu isolieren, die nicht in df2 sind, filtern wir den df_all-Datenrahmen durch Überprüfen Zeilen mit _merge gleich „left_only“. Dadurch erhalten wir das gewünschte Ergebnis.

Vermeidung häufiger Fallstricke:

Es ist wichtig zu beachten, dass einige Lösungen möglicherweise fälschlicherweise nach einzelnen Spaltenwerten suchen, anstatt sie abzugleichen Reihen als Ganzes. Solche Ansätze können zu falschen Ergebnissen führen, wie im folgenden Beispiel dargestellt:

~df1.col1.isin(common.col1) & ~df1.col2.isin(common.col2)
Nach dem Login kopieren

Dieser Code berücksichtigt nicht das gemeinsame Auftreten von Werten in Zeilen und kann zu falschen Ergebnissen führen, wenn Zeilen in df1 Werte enthalten, die einzeln erscheinen in df2, aber nicht in derselben Zeile.

Durch die Übernahme des oben beschriebenen Left-Join-Ansatzes stellen wir sicher, dass die abgeleiteten Zeilen korrekt als exklusiv für df1 identifiziert werden. Diese Technik bietet eine zuverlässige und effiziente Lösung zum Extrahieren von Zeilen, die in einem Datenrahmen vorhanden sind, in einem anderen jedoch nicht.

Das obige ist der detaillierte Inhalt vonWie extrahiere ich effizient Zeilen aus einem Pandas-DataFrame, die in einem anderen fehlen?. 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