亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

從另一個多索引數據幀的索引填充數據幀列的矢量化方法?

從另一個多索引數據幀的索引填充數據幀列的矢量化方法?

千巷貓影 2024-01-04 09:39:24
假設我有一個多索引數據框df1:        x   yi0  i1      aaa a   1   6    b   2   5    c   3   4bbb x   4   3    y   5   2    z   6   1使用第二個數據框df2:       foo         bar      cat0   0.925481    0.682102    aaa1   0.620557    0.375114    aaa2   0.788425    0.746436    bbb3   0.247594    0.902258    aaa4   0.146786    0.048585    bbb5   0.256904    0.327165    bbb我想使用第一個數據幀的二級索引列表將第二個數據幀中的列填充df2為數組,如下所示:       foo         bar      cat      catlist0   0.925481    0.682102    aaa   ['a','b','c']1   0.620557    0.375114    aaa   ['a','b','c']2   0.788425    0.746436    bbb   ['x','y','z']3   0.247594    0.902258    aaa   ['a','b','c']4   0.146786    0.048585    bbb   ['x','y','z']5   0.256904    0.327165    bbb   ['x','y','z']我可以通過迭代(緩慢地)來做到這一點,但是應該如何使用矢量化 pandas 方法來完成此操作?迭代使用apply:def iterate(row):    return list(df1.loc[row['cat']].index.get_level_values(0))df2['catlist'] = df2.apply(iterate, axis=1)
查看完整描述

1 回答

?
慕蓋茨4494581

TA貢獻1850條經驗 獲得超11個贊

您可以使用 將MultiIndex轉換為數據幀pd.MultiIndex.to_frame,然后使用 gropuby 并使用GroupBy.agg來列出?,F在映射在pd.Series.map

mapping = df1.index.to_frame(index=False).groupby("i0")["i1"].agg(list)

df2["catlist"] = df2["cat"].map(mapping)


? ? ? ? foo? ? ? ?bar? cat? ? catlist

0? 0.925481? 0.682102? aaa? [a, b, c]

1? 0.620557? 0.375114? aaa? [a, b, c]

2? 0.788425? 0.746436? bbb? [x, y, z]

3? 0.247594? 0.902258? aaa? [a, b, c]

4? 0.146786? 0.048585? bbb? [x, y, z]

5? 0.256904? 0.327165? bbb? [x, y, z]


查看完整回答
反對 回復 2024-01-04
  • 1 回答
  • 0 關注
  • 135 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號