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

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

將列從一個 pandas DataFrame 映射到另一個

將列從一個 pandas DataFrame 映射到另一個

眼眸繁星 2023-03-30 16:45:07
我有一個這樣的數據框:df_1 = pd.DataFrame({'players.name': ['John', 'Will' ,'John', 'Jim', 'Tim', 'John', 'Will', 'Tim'],                     'players.diff': [0, 0, 0, 0, 0, 0, 0, 0],                            'count': [3, 2, 3, 1, 2, 3, 2, 2]})'count' 值是常數。我有一個不同形狀的數據框,玩家的順序不同,如下所示:df_2 = pd.DataFrame({'players.name': ['Will', 'John' ,'Jim'],                     'players.diff': [0, 0, 0]})我如何從df_1值進行映射并在 上填充“計數”值df_2,最后得到:  players.name  players.diff  counts0         Will             0       21         John             0       32          Jim             0       1
查看完整描述

3 回答

?
Smart貓小萌

TA貢獻1911條經驗 獲得超7個贊

map由于您只是想創建一列計數,因此對您的玩家名稱進行計數會更有意義:

df_2['counts'] = df_2['players.name'].map(

? ? df_1.groupby('players.name')['count'].first())


df_2?


? players.name? players.diff? counts

0? ? ? ? ?Will? ? ? ? ? ? ?0? ? ? ?2

1? ? ? ? ?John? ? ? ? ? ? ?0? ? ? ?3

2? ? ? ? ? Jim? ? ? ? ? ? ?0? ? ? ?1


查看完整回答
反對 回復 2023-03-30
?
湖上湖

TA貢獻2003條經驗 獲得超2個贊

這可以工作:

pd.merge(df_1, df_2, on=["players.name", "players.diff"]).drop_duplicates()


查看完整回答
反對 回復 2023-03-30
?
德瑪西亞99

TA貢獻1770條經驗 獲得超3個贊

您的樣本df_1重復了players.name相同的計數,因此您需要 left-merge 和 drop_duplicates


new_df_2 = df_2.merge(df_1[['players.name','count']], on='players.name', how='left').drop_duplicates()


Out[89]:

  players.name  players.diff  count

0         Will             0      2

2         John             0      3

5          Jim             0      1


查看完整回答
反對 回復 2023-03-30
  • 3 回答
  • 0 關注
  • 204 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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