如何使用「groupby」連接 Pandas DataFrame 中群組內的字串?
Pandas groupby:取得字串連線
使用其中一列包含字串的DataFrame 時,預設sum() 函數可能並不總是能提供期望的結果。在這種情況下,目標是連接每個群組的字串,這裡有一個全面的解釋和解決方案。
考慮以下DataFrame:
A B C 0 1 0.749065 This 1 2 0.301084 is 2 3 0.463468 a 3 4 0.643961 random 4 1 0.866521 string 5 2 0.120737 !
預設情況下,應用sum()到列「C」會產生以下輸出:
A 1 Thisstring 2 is! 3 a 4 random dtype: object
要取得為每個群組連接字串的所需輸出,有多種方法:
使用apply () 函數:
一種方法是將自訂函數應用於groupby對象。此函數可以連接每個組內的字串。
<code class="python">def f(x): return Series(dict(A = x['A'].sum(), B = x['B'].sum(), C = "{%s}" % ', '.join(x['C']))) df.groupby('A').apply(f)</code>
或:
您可以透過明確使用apply() 和lambda 函數來獲得相同的結果:
<code class="python">df.groupby('A')['C'].apply(lambda x: "{%s}" % ', '.join(x))</code>
應用自訂邏輯:
如果需要自訂,例如刪除空字串或套用特定分隔符,您可以在lambda 函數中實作自己的邏輯。
例如,要刪除空字串:
<code class="python">df.groupby('A')['C'].apply(lambda x: "{%s}" % ', '.join([c for c in x if c]))</code>
效能注意事項:
請注意,套用自訂函數可能比使用內建sum() 函數。因此,建議根據您的具體需求考慮效能影響。
以上是如何使用「groupby」連接 Pandas 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)

Linux終端中查看Python版本時遇到權限問題的解決方法當你在Linux終端中嘗試查看Python的版本時,輸入python...

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

在使用Python的pandas庫時,如何在兩個結構不同的DataFrame之間進行整列複製是一個常見的問題。假設我們有兩個Dat...

Uvicorn是如何持續監聽HTTP請求的? Uvicorn是一個基於ASGI的輕量級Web服務器,其核心功能之一便是監聽HTTP請求並進�...

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

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