Python中文
首页
教程
问答
标签
搜索
登录
注册
Pandas匹配两个数据帧中的两列,并在df1中创建新列
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我有两个数据帧</p> <p>df1型</p> <pre><code>Srlno id image 1 3 image1.jpg 2 3 image2.jpg 3 3 image2.jpg </code></pre> <p>df2型</p> <pre><code>Srlno id image 1 1 image1.jpg 2 2 image2.jpg 3 3 image3.jpg </code></pre> <p>我想基于列映像匹配这两个数据帧,并将Id作为newcolumn从df2返回到df1。df2中的图像名称是唯一的,而df1中的图像名称有很多重复项。我想保留重复的图像名称,但为df2中的每个图像填写正确的id。你知道吗</p> <p>预期输出为:</p> <pre><code>Srlno id image newids 1 3 image1.jpg 1 2 3 image2.jpg 2 3 3 image2.jpg 2 </code></pre> <p>我试过了</p> <pre><code>df1['newids'] = df1['image'].map(df2.set_index('image')['id']) </code></pre> <p>这将返回一个错误InvalidInvexError('Reindexing only valid with unique value index objects')我知道df1中的重复项产生了这个错误…但不知道如何解决。你知道吗</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>另一个有<code>dict(zip())</code>的解决方案</p> <pre><code>df1['newids']=df1.image.map(dict(zip(df2.image,df2.id))) print(df1) Srlno id image newids 0 1 3 image1.jpg 1 1 2 3 image2.jpg 2 2 3 3 image2.jpg 2 </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
我想从用户inpu创建一个类的实例
6 回答
我想从用户导入值,为此
6 回答
我想从用户那里得到一个整数输入,然后让for循环遍历该数字,然后调用一个函数多次
8 回答
我想从用户那里收到一个列表,并在其中执行一些步骤,然后在步骤完成后将其打印回来,但它没有按照我想要的方式工作
6 回答
我想从用户那里获取输入,并将值传递给(average=dict[x]/6),然后在那里获取resu
9 回答
我想从第一个列表中展示第一个词,然后从第二个列表中展示十个词,以此类推- Python
10 回答
我想从第一个空lin开始解析文本文件
4 回答
我想从简历、简历中提取特定部分
8 回答
我想从给定字典(python)的字符串中删除\u00a9、\u201d和类似的字符。
1 回答
我想从给定的网站Lin下载许多文件扩展名相同的Wget或Python文件
1 回答
我想从网上搜集一些关于抵押贷款的数据
10 回答
我想从网站上删除电子邮件地址
9 回答
我想从网站上读取数据该网站包含可下载的文件,然后我想用python脚本把它发送给oracle如何?
1 回答
我想从网站中提取数据,然后将其显示在我的网页上
2 回答
我想从网页上提取统计数据。
8 回答
我想从网页上解析首都城市,并在用户输入国家时在终端上打印它们
10 回答
我想从色彩图中删除前n个颜色,而不丢失原始颜色数
5 回答
我想从课堂上打印字典里的键
8 回答
我想从费用表中获取学生上次支付的费用,其中学生id=id
4 回答
我想从较低的顺序对多重列表进行排序,但我无法在一行中生成结果
8 回答