Heim > Backend-Entwicklung > Python-Tutorial > Wie kann man Pandas-DataFrame-Werte basierend auf einer Bedingung effizient ersetzen?

Wie kann man Pandas-DataFrame-Werte basierend auf einer Bedingung effizient ersetzen?

Barbara Streisand
Freigeben: 2024-12-22 09:03:24
Original
695 Leute haben es durchsucht

How to Efficiently Replace Pandas DataFrame Values Based on a Condition?

Bedingtes Ersetzen in Pandas-Datenrahmen

In Pandas-Datenrahmen ist das Ersetzen von Werten basierend auf einer Bedingung eine häufige Aufgabe. Stellen Sie sich eine Situation vor, in der Sie Werte in einer bestimmten Spalte auf Null setzen müssen, wenn sie einen Schwellenwert überschreiten.

Ursprünglicher Ansatz:

Ein gängiger Ansatz, um dies zu erreichen, ist durch Verwendung des Indexers df[].ix, der in den Pandas-Versionen 0.20.0 und 0.20.0 veraltet ist höher.

df[df.my_channel > 20000]['my_channel'] = 0
Nach dem Login kopieren

Alternative Lösungen:

Mit der Einführung der loc- und iloc-Indexer lautet die empfohlene Methode zur Durchführung bedingter Ersetzungen:

Verwendung des Loc-Indexers:

mask = df['my_channel'] > 20000
df.loc[mask, 'my_channel'] = 0
Nach dem Login kopieren

Der Loc Der Indexer ermöglicht die Zeilen- und Spaltenauswahl basierend auf booleschen Masken. In diesem Fall wählt die Maske die Zeilen aus, in denen df['my_channel'] > 20000, und diese Zeilen werden in der Spalte „my_channel“ auf Null gesetzt.

Verwendung des iloc-Indexers:

mask = df['my_channel'] > 20000
df.iloc[mask.index, df.columns.get_loc('my_channel')] = 0
Nach dem Login kopieren

Der iloc-Indexer ermöglicht eine Auswahl basierend auf Ganzzahlindizes. In diesem Fall werden die Maskenindizes verwendet, um die Zeilen auszuwählen, und der Spaltenindex von „my_channel“ wird verwendet, um die Werte auf Null zu setzen.

Hinweis: In diesem speziellen Fall Die Verwendung des loc-Indexers wird gegenüber dem iloc-Indexer empfohlen, da iloc keine boolesche Indizierung für ganzzahlige Spalten unterstützt.

Das obige ist der detaillierte Inhalt vonWie kann man Pandas-DataFrame-Werte basierend auf einer Bedingung effizient ersetzen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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