将两个时间表与一些省略的数据合并

问题描述 投票:4回答:2

我有两个数据帧:

df_old:

A   B   C   D   E
1   b1  c   d1  e1
2   b2  c   d2  e2
3   b3  c   d3  e3

DF:

A   B   C    D   F  
2   b2  c2   d0  f2
4   b4  c1   d4  f4
5   b5  c2   d5  f5

我希望他们合并到:

A   B   C    D   E   F  
1   b1  c   d1  e1   
2   b2  c2  d2  e2   f2
3   b3  c   d3  e3   
4   b4  c1  d4       f4
5   b5  c2  d5       f5

我使用这段代码,但是在省略行时会出现问题,例如df ['A']第1行和第3行:

df1 = df_old.loc[:,df_old.columns != 'C']
df2 = df.loc[:len(df_old)-1, df.columns != 'B']
df2 = df2.loc[:, df2.columns != 'D']
df_m = pandas.merge(df1, df2,
                            how='outer', on=['A'])
df_m = pandas.merge(df_m, df.loc[len(df_old)-1:, ],
                            how='outer', on=['A', 'B', 'D', 'F']) 
python pandas merge time-series
2个回答
4
投票

combine_first一起玩

df_old.set_index('A',inplace=True)
df1.set_index('A',inplace=True)
yourdf=df_old.combine_first(df1)
yourdf.reset_index(inplace=True)

yourdf.update(df1[['C']])
yourdf
Out[80]: 
    B   C   D    E    F
A                      
1  b1   c  d1   e1  NaN
2  b2  c2  d2   e2   f2
3  b3   c  d3   e3  NaN
4  b4  c1  d4  NaN   f4
5  b5  c2  d5  NaN   f5

1
投票

appendgroupby / agglast / first

在某些列中,您希望保留第一个数据帧中的一个。在其他列中,您更喜欢第二个数据帧中的值。如果你使用agg,你可以控制哪些列做哪些。确保append按照您选择的last / first有意义的顺序排列。

d = {'B': 'last', 'C': 'last', 'D': 'first', 'E': 'last', 'F': 'first'}
df_old.append(df).groupby('A', as_index=False).agg(d)

   A   B   C   D    E    F
0  1  b1   c  d1   e1  NaN
1  2  b2  c2  d2   e2   f2
2  3  b3   c  d3   e3  NaN
3  4  b4  c1  d4  NaN   f4
4  5  b5  c2  d5  NaN   f5
© www.soinside.com 2019 - 2024. All rights reserved.