回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我有一个数据框,我想用另一个数据框中的值替换一列中的值。</p>
<pre><code>df = pd.DataFrame({'id1': [1001,1002,1001,1003,1004,1005,1002,1006],
'value1': ["a","b","c","d","e","f","g","h"],
'value3': ["yes","no","yes","no","no","no","yes","no"]})
dfReplace = pd.DataFrame({'id2': [1001,1002],
'value2': ["rep1","rep2"]})
</code></pre>
<p>我需要使用带有公共密钥的groupby,而当前的解决方案是使用循环。是否有更优雅(更快)的方法来处理.map(apply)等。我希望initial使用pd.update(),但似乎不是正确的方法。</p>
<pre><code>groups = dfReplace.groupby(['id2'])
for key, group in groups:
df.loc[df['id1']==key,'value1']=group['value2'].values
</code></pre>
<p>输出</p>
<pre><code>df
id1 value1 value3
0 1001 rep1 yes
1 1002 rep2 no
2 1001 rep1 yes
3 1003 d no
4 1004 e no
5 1005 f no
6 1002 rep2 yes
7 1006 h no
</code></pre>