簡體   English   中英

在 pandas dataframe 中使用另一個 dataframe 的行中的多個值查找值

[英]lookup value in the pandas dataframe using the muliple values in the row of another dataframe

我有數據框:

df1:
| |A|B|C|D|E|
|0|1|2|3|4|5|
|1|1|3|4|5|0|
|2|3|1|2|3|5|
|3|2|3|1|2|6|
|4|2|5|1|2|3|

df2:
| |K|L|M|N|
|0|1|3|4|2|
|1|1|2|5|3|
|2|3|2|3|1|
|3|1|4|5|0|
|4|2|2|3|6|
|5|2|1|2|7|

我需要做的是將df1的A列與df2的k列匹配; df1 的列 C 與 df2 的 L; df1 的 D 列和 df2 的 M 列。 如果值匹配,則應將 df2 中 N 的相應值分配給 df1 中的新列 F。 output 應該是:

| |A|B|C|D|E|F|
|0|1|2|3|4|5|2|
|1|1|3|4|5|0|0|
|2|3|1|2|3|5|1|
|3|2|3|1|2|6|7|
|4|2|5|1|2|3|7|

DataFrame.merge與左連接和重命名列一起使用以進行匹配:

df = df1.merge(df2.rename(columns={'K':'A','L':'C','M':'D', 'N':'F'}), how='left')
print (df)
   A  B  C  D  E  F
0  1  2  3  4  5  2
1  1  3  4  5  0  0
2  3  1  2  3  5  1
3  2  3  1  2  6  7
4  2  5  1  2  3  7
df3 = df1.join(df2)
F = []
for _, row in df3.iterrows():
    if row['A'] == row['K'] and row['C'] == row['L'] and row['D'] == row['M']:
        F.append(row['N'])
    else:
        F.append(0)
df1['F'] = F
df1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM