简体   繁体   English

连接两个熊猫数据框

[英]joining two panda dataframes

I am having trouble merging these two dataframes to give the expected results. 我在合并这两个数据框以达到预期结果时遇到了麻烦。 I would like to check both dataframes and if column 1 and 3 of dataframe 1 match column 0 and 2 of dataframe 2 then return the last dataframe. 我想检查两个数据帧,如果数据帧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

You could try this using an inner join with merge : 您可以使用带有merge的内部联接来尝试此操作:

df1[['1','3']].merge(df2, left_on=['1','3'], right_on=['0','2'], suffixes=('_x',''))\
              .drop(['1_x','3_x'], axis=1)

尝试这个:

result = df1.merge(df2, left_on=['1', '3'], right_on=['0', '2']) 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM