我很难合并这两个数据框以提供预期的结果。我想检查两个数据帧,如果数据帧1的第1列和第3列与数据帧2的第0列和第2列相匹配,则返回最后一个数据帧。
df1
0 1 2 3 4 5
4 4133 43 192.168.0.1 dt1 default
5 4134 43 192.168.0.2 dt2 t2
6 4135 43 192.168.0.3 dt3 t3
df2
0 1 2 3 4 5
4134 43 192.168.0.2 dt2 t2
4136 43 192.168.0.4 dt4 default
4137 43 192.168.0.5 dt5 default
result
0 1 2 3 4 5
5 4134 43 192.168.0.2 dt2 t2
答案 0 :(得分:2)
您可以使用带有merge
的内部联接来尝试此操作:
df1[['1','3']].merge(df2, left_on=['1','3'], right_on=['0','2'], suffixes=('_x',''))\
.drop(['1_x','3_x'], axis=1)
答案 1 :(得分:0)
尝试一下:
result = df1.merge(df2, left_on=['1', '3'], right_on=['0', '2'])