首頁 > 後端開發 > Python教學 > 如何根據條件從 Pandas DataFrame 中刪除行?

如何根據條件從 Pandas DataFrame 中刪除行?

DDD
發布: 2024-11-12 08:50:02
原創
240 人瀏覽過

How to Remove Rows from a Pandas DataFrame Based on a Condition?

Pandas DataFrames 中行的條件刪除

最初的問題試圖根據特定列的字串長度從 DataFrame 中刪除行。雖然提出的解決方案不正確,但本文旨在提供對 Pandas 中條件行刪除的全面理解。

使用 drop 方法

直接解決標題的問題,drop 方法提供了一種基於條件表達式消除行的簡單方法。語法如下:

df = df.drop(some labels)
df = df.drop(df[<some boolean condition>].index)
登入後複製

範例

要刪除分數列值小於50 的所有行:

df = df.drop(df[df.score < 50].index)
登入後複製

對於就地修改,您可以使用:

df.drop(df[df.score < 50].index, inplace=True)
登入後複製

多個條件

Pandas 支援使用邏輯運算子(| 表示OR,& 表示AND,~ 表示NOT)來建立複雜條件。請記住將它們括在括號中。

要刪除分數既小於 50 又大於 20 的所有行:

df = df.drop(df[(df.score < 50) & (df.score > 20)].index)
登入後複製

以上是如何根據條件從 Pandas DataFrame 中刪除行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板