如何在熊猫中使用索引连接两个数据框?

时间:2019-02-01 11:59:13

标签: python pandas dataframe

我有以下数据框df1

         value
0     0.164560
1     0.000000
2     0.350000
3     0.700000
    ...
3778  0.350000
3779  0.000000
3780  0.137500
3781  0.253333

和另一个数据框df2

                 0             1
2669  1.744478e-05  2.323815e-05
5417  2.274561e-06  5.808474e-04
6102  2.220705e-06  1.605110e-04
4033  2.018643e-04  2.867235e-05
4877  4.549740e-07  6.233500e-04
             ...
4470  2.761791e-06  6.504309e-05
5071  1.261781e-06  8.010408e-05
3635  4.810822e-05  3.325764e-05
5378  1.133819e-04  4.934986e-05
通过连接两个数据帧,我希望通过从df2中删除列0和1,使df2中的索引成为连接数据框中的id列。所以所需的输出看起来像

  id         value
2669     0.164560
5417     0.000000
6102     0.350000
4033     0.700000
    ...
4470     0.350000
5071     0.000000
3635     0.137500
5378     0.253333

我尝试了

df3 = pd.concat([df2, df1], ignore_index=True)

使用pd.concat连接的数据框的输出

         value             0             1
0     0.164560           NaN           NaN
1     0.000000           NaN           NaN
2     0.350000           NaN           NaN
3     0.700000           NaN           NaN
          ....
7382       NaN  4.165176e-05  2.615312e-05
7383       NaN  2.357132e-05  5.779454e-05
7384       NaN  1.761602e-06  7.960426e-05
7385       NaN  9.162049e-11  1.627316e-04

1 个答案:

答案 0 :(得分:2)

如果两个DataFrame的长度相同,则仅将一个索引分配给新列:

df1['id'] = df2.index
print (df1)

或者:

df1 = df1.assign(id = df2.index)
print (df1)