目錄
多條件高效過濾 Pandas DataFrame 或 Series
首頁 後端開發 Python教學 如何有效率地過濾具有多個條件的 Pandas DataFrame 或 Series?

如何有效率地過濾具有多個條件的 Pandas DataFrame 或 Series?

Oct 20, 2024 am 11:56 AM

How to Efficiently Filter Pandas DataFrame or Series with Multiple Conditions?

多條件高效過濾 Pandas DataFrame 或 Series

Pandas 提供了多種過濾資料的方法,包括 reindex()、apply() 和 map() 。然而,當應用多個過濾器時,效率就成為一個問題。

為了最佳化過濾,請考慮使用布林索引。 Pandas 和 Numpy 都支援布林索引,它直接對底層資料數組進行操作,而不會創建不必要的副本。

以下是布林索引的範例:

<code class="python">df.loc[df['col1'] >= 1, 'col1']</code>
登入後複製

此表達式傳回包含下列內容的 Pandas Series:僅列「col1」中的值大於或等於 1 的行。

要套用多個篩選器,請使用邏輯運算子「&」(AND)和「|」 (或)。例如:

<code class="python">df[(df['col1'] >= 1) &amp; (df['col1'] <=1 )]</code>
登入後複製

此表達式傳回一個 DataFrame,僅包含列「col1」中的值在 1 和 1 之間(含 1 和 1)的行。

對於輔助函數,請考慮定義以下函數:取得一個 DataFrame 並傳回一個布林系列,讓您可以使用邏輯運算子組合多個篩選器。

<code class="python">def b(x, col, op, n):
    return op(x[col],n)

def f(x, *b):
    return x[(np.logical_and(*b))]</code>
登入後複製

Pandas 0.13 引入了 query() 方法,該方法提供了一種更有效的方式來表達複雜的過濾條件。假設有效的列標識符,以下程式碼根據多個條件過濾DataFrame df:

<code class="python">df.query('col1 <= 1 &amp; 1 <= col1')</code>
登入後複製

總之,布林索引提供了一種有效的方法,可以將多個過濾器應用於Pandas DataFrame 或Series ,而無需建立不必要的副本。使用邏輯運算子和輔助函數組合多個篩選器以實現擴充功能。

以上是如何有效率地過濾具有多個條件的 Pandas DataFrame 或 Series?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到? 如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到? Apr 02, 2025 am 07:15 AM

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

在Linux終端中使用python --version命令時如何解決權限問題? 在Linux終端中使用python --version命令時如何解決權限問題? Apr 02, 2025 am 06:36 AM

Linux終端中使用python...

如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎? 如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎? Apr 02, 2025 am 07:18 AM

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

如何繞過Investing.com的反爬蟲機制獲取新聞數據? 如何繞過Investing.com的反爬蟲機制獲取新聞數據? Apr 02, 2025 am 07:03 AM

攻克Investing.com的反爬蟲策略許多人嘗試爬取Investing.com(https://cn.investing.com/news/latest-news)的新聞數據時,常常�...

Python 3.6加載pickle文件報錯ModuleNotFoundError: No module named '__builtin__'怎麼辦? Python 3.6加載pickle文件報錯ModuleNotFoundError: No module named '__builtin__'怎麼辦? Apr 02, 2025 am 06:27 AM

Python3.6環境下加載pickle文件報錯:ModuleNotFoundError:Nomodulenamed...

使用Scapy爬蟲時,管道文件無法寫入的原因是什麼? 使用Scapy爬蟲時,管道文件無法寫入的原因是什麼? Apr 02, 2025 am 06:45 AM

使用Scapy爬蟲時管道文件無法寫入的原因探討在學習和使用Scapy爬蟲進行數據持久化存儲時,可能會遇到管道文�...

See all articles