第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

基于優(yōu)先級過濾 pandas DataFrame 的高效/Pythonic 方法

基于優(yōu)先級過濾 pandas DataFrame 的高效/Pythonic 方法

慕勒3428872 2023-05-09 10:13:14
我有以下數(shù)據(jù)框。+-----------+----------+-----+| InvoiceNo | ItemCode | Qty |+-----------+----------+-----+|  Inv-001  |     A    |  2  |+-----------+----------+-----+|  Inv-001  |     B    |  3  |+-----------+----------+-----+|  Inv-001  |     C    |  1  |+-----------+----------+-----+|  Inv-002  |     B    |  3  |+-----------+----------+-----+|  Inv-002  |     D    |  4  |+-----------+----------+-----+|  Inv-003  |     C    |  3  |+-----------+----------+-----+|  Inv-003  |     D    |  9  |+-----------+----------+-----+|  Inv-004  |     D    |  5  |+-----------+----------+-----+|  Inv-004  |     E    |  8  |+-----------+----------+-----+|  Inv-005  |     X    |  2  |+-----------+----------+-----+Type我的任務(wù)是根據(jù)項目出現(xiàn)的優(yōu)先級創(chuàng)建一個附加列。例如:ItemCode A有1st優(yōu)先權(quán)。然后B有2nd優(yōu)先權(quán),C有3rd優(yōu)先權(quán)。其余項目有l(wèi)east優(yōu)先級和分類有Other。因此,如果任何 Invoice 包含 item A,則類型應(yīng)該Type - A與其他項目無關(guān)。來自余額發(fā)票如果項目B包含,則類型應(yīng)該是Type - B。同樣的C。如果 none ofA, B or C不存在于任何發(fā)票中,則類型應(yīng)為Type - Other。下面是我想要的輸出。+-----------+----------+-----+--------------+| InvoiceNo | ItemCode | Qty |     Type     |+-----------+----------+-----+--------------+|  Inv-001  |     A    |  2  |   Type - A   |+-----------+----------+-----+--------------+|  Inv-001  |     B    |  3  |   Type - A   |+-----------+----------+-----+--------------+|  Inv-001  |     C    |  1  |   Type - A   |+-----------+----------+-----+--------------+|  Inv-002  |     B    |  3  |   Type - B   |+-----------+----------+-----+--------------+|  Inv-002  |     D    |  4  |   Type - B   |+-----------+----------+-----+--------------+|  Inv-003  |     C    |  3  |   Type - C   |+-----------+----------+-----+--------------+|  Inv-003  |     D    |  9  |   Type - C   |+-----------+----------+-----+--------------+|  Inv-004  |     D    |  5  | Type - Other |+-----------+----------+-----+--------------+|  Inv-004  |     E    |  8  | Type - Other |+-----------+----------+-----+--------------+|  Inv-005  |     X    |  2  | Type - Other |+-----------+----------+-----+--------------+現(xiàn)在,最重要efficient的pythonic方法是什么?
查看完整描述

1 回答

?
江戶川亂折騰

TA貢獻1851條經(jīng)驗 獲得超5個贊

我覺得我們可以Categorical做到transform


df['Type']=pd.Categorical(df.ItemCode,['A','B','C'],ordered=True)


df['Type']='Type_'+df.groupby('InvoiceNo')['Type'].transform('min').fillna('other')

更新


df['Type']=pd.Categorical(df.ItemCode,['A','B','C'],ordered=True)

df=df.sort_values('Type')

df['Type']='Type_'+df.groupby('InvoiceNo')['Type'].transform('first').fillna('other')

df=df.sort_index()


df

Out[32]: 

     InvoiceNo ItemCode  Qty        Type

0    Inv-001          A    2      Type_A

1    Inv-001          B    3      Type_A

2    Inv-001          C    1      Type_A

3    Inv-002          B    3      Type_B

4    Inv-002          D    4      Type_B

5    Inv-003          C    3      Type_C

6    Inv-003          D    9      Type_C

7    Inv-004          D    5  Type_other

8    Inv-004          E    8  Type_other

9    Inv-005          X    2  Type_other


查看完整回答
反對 回復(fù) 2023-05-09
  • 1 回答
  • 0 關(guān)注
  • 113 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號