gpt4 book ai didi

python - Pandas 比较两列,如果仅第一个唯一值匹配,则复制另一列的值

转载 作者:行者123 更新时间:2023-11-30 22:04:52 25 4
gpt4 key购买 nike

我有两个不同的数据帧,我想比较其中的两列。如果第一个数据帧的值出现在第二个数据帧的列中的任何位置,我想复制匹配值旁边的值并将其复制到第一个数据帧中的新列。

数据框如下所示:

DF1

╔═══════════════════╗
║ Email ║
╠═══════════════════╣
║ Johndoe@gmail.com ║
║ janedoe@gmail.com ║
║ foo@gmail.com ║
║ foobar@gmail.com ║
║ bar@gmail.com ║
╚═══════════════════╝

DF2

╔════════════════════╦═════════════╗
║ Email ║ Phone ║
╠════════════════════╬═════════════╣
║ Johndoe@gmail.com ║ 111-111-111 ║
║ Johndoe@gmail.com ║ 111-111-111 ║
║ Johndoe@gmail.com ║ 111-111-111 ║
║ Jakedoe@gmail.com ║ 123-123-123 ║
║ jamesdoe@gmail.com ║ 321-321-321 ║
║ janedoe@gmail.com ║ 222-222-222 ║
║ janedoe@gmail.com ║ 222-222-222 ║
║ foo@gmail.com ║ 333-333-333 ║
║ foobar@gmail.com ║ 444-444-444 ║
║ foobar@gmail.com ║ 444-444-444 ║
║ bar@gmail.com ║ 555-555-555 ║
╚════════════════════╩═════════════╝

输出应如下所示:

╔═══════════════════╦═════════════╗
║ email ║ phone ║
╠═══════════════════╬═════════════╣
║ Johndoe@gmail.com ║ 111-111-111 ║
║ janedoe@gmail.com ║ 222-222-222 ║
║ foo@gmail.com ║ 333-333-333 ║
║ foobar@gmail.com ║ 444-444-444 ║
║ bar@gmail.com ║ 555-555-555 ║
╚═══════════════════╩═════════════╝

我尝试循环 DF1 中的列并将每个值与 DF2 中的相应列进行比较,但它也返回重复项。

使用 Pandas 实现这一目标的好方法是什么?

谢谢!

最佳答案

您可以使用 .merge()然后.drop_duplicates()

new_df = df1.merge(df2, on='Email', how='left').drop_duplicates()

关于python - Pandas 比较两列,如果仅第一个唯一值匹配,则复制另一列的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53158398/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com