pandas:合并数据帧并替换值

时间:2017-01-12 20:18:19

标签: python pandas numpy

我有两个数据帧:

   A = pd.DataFrame(data=np.array([['t1',1,'t2',2]]).reshape(2,2),columns=['a','b'])

A
Out[6]: 
    a  b
0  t1  1
1  t2  2

B = pd.DataFrame(data=np.array([[1,2,3],[2,5,6],[3,6,7]]).reshape(3,3),columns=['x','y','z'])

B
Out[8]: 
   x  y  z
0  1  2  3
1  2  5  6
2  3  6  7

我试图基本匹配“b”数据帧A上的数据帧B的列'x',但将匹配的值替换为数据帧A的列'a'。

即。我想合并两个数据帧,以便输出如下所示:

   x   y  z
0  t1  2  3
1  t2  5  6
2  3   6  7

任何想法如何解决这个问题?

1 个答案:

答案 0 :(得分:5)

B.loc[B.x.astype(str).isin(A.b), 'x'] = A.a

B

    x  y  z
0  t1  2  3
1  t2  5  6
2   3  6  7