Heim Backend-Entwicklung Python-Tutorial Wie werte ich Ausdrücke in Pandas mithilfe von pd.eval(), DataFrame.eval() und DataFrame.query() dynamisch aus?

Wie werte ich Ausdrücke in Pandas mithilfe von pd.eval(), DataFrame.eval() und DataFrame.query() dynamisch aus?

Nov 20, 2024 am 04:14 AM

How to Dynamically Evaluate Expressions in Pandas Using pd.eval(), DataFrame.eval(), and DataFrame.query()?

Dynamisches Auswerten eines Ausdrucks aus einer Formel in Pandas

In Pandas gibt es mehrere Möglichkeiten, einen Ausdruck aus einer Formel dynamisch auszuwerten:

1. pd.eval()

Diese Funktion wertet arithmetische Ausdrücke unter Verwendung einer Zeichenfolge als Eingabe aus. Es unterstützt mathematische Operationen, logische Operatoren und bedingte Anweisungen. Sie können es wie folgt verwenden:

expression = "df1['A'] + (df1['B'] * x)"
pd.eval(expression)
Nach dem Login kopieren

2. DataFrame.eval()

Ähnlich wie pd.eval() wertet diese Methode Ausdrücke innerhalb eines DataFrame aus. Es bietet eine bequeme Möglichkeit, auf Spalten zuzugreifen, ohne „df1“ anzugeben. Präfix.

df1.eval("A + (B * x)")
Nach dem Login kopieren

3. DataFrame.query()

Diese Funktion wertet einen bedingten Ausdruck aus und gibt eine boolesche Maske zurück. Anschließend können Sie die Maske verwenden, um den DataFrame zu filtern.

condition = "A >= B"
df1.query(condition)
Nach dem Login kopieren

Antworten auf spezifische Fragen:

  1. Optimale Leistung:Verwenden pd.eval() oder DataFrame.eval() mit dem „numexpr“-Backend. Das „Python“-Backend bietet keine Leistungsvorteile und birgt Sicherheitsrisiken.
  2. Ergebnisse zuweisen: Sie können das Ergebnis eines Ausdrucks mithilfe des „target=" wieder einem DataFrame zuweisen. Argument.

    df2 = pd.DataFrame()
    pd.eval("df2['D'] = df1['A'] + (df1['B'] * x)", target=df2)
    Nach dem Login kopieren
  3. Übergabe von Argumenten: Sie können Argumente als Variablen innerhalb des Ausdrucks übergeben, indem Sie das „@“-Symbol verwenden.

    expression = "df1['A'] + (@x * df1['B'])"
    pd.eval(expression, local_dict={"x": 5})
    Nach dem Login kopieren

Zusätzliche Überlegungen:

  • Wählen Sie die geeignete Methode basierend auf Ihren Bedürfnissen und der Art des Ausdrucks, den Sie bewerten.
  • Verwenden Sie Klammern für die Operatorpriorität, wenn nötig.
  • Das Argument „resolvers=" kann verwendet werden, um benutzerdefinierte Funktionen oder Variablen zur Verwendung im Ausdruck bereitzustellen.
  • Für mehrzeilige Ausdrücke und Zuweisungen verwenden Sie DataFrame.eval (), da query() nur eine einzeilige Bedingung akzeptiert.

Das obige ist der detaillierte Inhalt vonWie werte ich Ausdrücke in Pandas mithilfe von pd.eval(), DataFrame.eval() und DataFrame.query() dynamisch aus?. 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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Mar 10, 2025 pm 06:54 PM

Wie benutze ich eine schöne Suppe, um HTML zu analysieren?

Bildfilterung in Python Bildfilterung in Python Mar 03, 2025 am 09:44 AM

Bildfilterung in Python

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden Mar 05, 2025 am 09:58 AM

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden

Wie man mit PDF -Dokumenten mit Python arbeitet Wie man mit PDF -Dokumenten mit Python arbeitet Mar 02, 2025 am 09:54 AM

Wie man mit PDF -Dokumenten mit Python arbeitet

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Mar 02, 2025 am 10:10 AM

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Mar 10, 2025 pm 06:52 PM

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?

Serialisierung und Deserialisierung von Python -Objekten: Teil 1 Serialisierung und Deserialisierung von Python -Objekten: Teil 1 Mar 08, 2025 am 09:39 AM

Serialisierung und Deserialisierung von Python -Objekten: Teil 1

So implementieren Sie Ihre eigene Datenstruktur in Python So implementieren Sie Ihre eigene Datenstruktur in Python Mar 03, 2025 am 09:28 AM

So implementieren Sie Ihre eigene Datenstruktur in Python

See all articles