如何有效地選擇 Pandas MultiIndex DataFrame 中的行?
在Pandas MultiIndex DataFrame 中選擇行
問題摘要
給定一個帶有MultiIndex 的Pandas DataFrame,我們如何根據特定值選擇行/每個索引等級中的標籤?
切片loc
df.loc[key, :]
- key 是一個標籤元組,每個索引等級一個。
- 這提供了一種方便而簡潔的方法來根據不同層級中的特定值來選擇行。
切片xs
df.xs(level_key, level=level_name, drop_level=True/False)
- level_key 是特定索引等級的鍵。
- drop_level 控制是否應從產生的 DataFrame 中刪除該等級。
- xs 是在單一層級上切片時特別有用。
過濾query
df.query("condition")
- condition 是一個布林表達式,指定過濾條件。
- 支援跨多個索引層級的靈活過濾。
使用 get_level_values
mask = df.index.get_level_values(level_name).isin(values_list) selected_rows = df[mask]
- 建立一個布林值基於特定索引等級中的值的遮罩。
- 對於更複雜的過濾操作或對多個值進行切片時很有用。
範例
範例1:選擇等級「一」中具有特定值的行,且'two':
# Using loc selected_rows = df.loc[['a'], ['t', 'u']] # Using xs selected_rows = df.xs('a', level='one', drop_level=False) selected_rows = selected_rows.xs(['t', 'u'], level='two') # Using query selected_rows = df.query("one == 'a' and two.isin(['t', 'u'])") # Using get_level_values one_mask = df.index.get_level_values('one') == 'a' two_mask = df.index.get_level_values('two').isin(['t', 'u']) selected_rows = df[one_mask & two_mask]
範例2:依等級'two'中的數值不等式過濾行:
# Using query selected_rows = df.query("two > 5") # Using get_level_values two_mask = df.index.get_level_values('two') > 5 selected_rows = df[two_mask]
提示和注意事項
- 考慮切片/過濾操作的複雜性並相應地選擇適當的方法。
- 對於單一或幾個等級的簡單切片,首選 loc 或 xs。
- 對於多個值的複雜過濾或切片,請考慮使用 query 或 get_level_values 作為它們提供了更大的靈活性。
- 注意使用 pd.IndexSlice 來指定複雜的切片操作loc.
- sort_index() 可以提高具有未排序 MultiIndex 的大型 DataFrame 的效能。
以上是如何有效地選擇 Pandas MultiIndex DataFrame 中的行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

Python在開發效率上優於C ,但C 在執行性能上更高。 1.Python的簡潔語法和豐富庫提高開發效率。 2.C 的編譯型特性和硬件控制提升執行性能。選擇時需根據項目需求權衡開發速度與執行效率。

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。
