为了账号安全,请及时绑定邮箱和手机立即绑定

Pandas 匹配数据帧结构

Pandas 匹配数据帧结构

至尊宝的传说 2022-01-05 11:33:07
我有两个数据框,如下所示:d = {'var1': [1, 2, 3, 4], 'var2': [5, 6, 7, 8], 'var3': [9, 10, 11, 12]}df = pd.DataFrame(data=d)df    var1   var2  var30     1     5      91     2     6      102     3     7      113     4     8      12和d2 = {'var1': [4, 1, 3], 'var2': [5, 7, 7]}df2 = pd.DataFrame(data=d2)df2    var1   var20     1     51     2     72     3     7我希望 df2 具有与原始 df 相同的列和列顺序所以结果看起来像:df2    var1   var2  var30     1     5     NaN1     2     7     NaN2     3     7     NaN我知道我可以在此示例中手动分配一个名为“var3”的新列并将其值设置为 NaN,但我正在寻找一种通用解决方案,需要在具有许多列的许多数据帧上完成此操作。
查看完整描述

3 回答

?
三国纷争

TA贡献1804条经验 获得超7个赞

使用 align


df2,_=df2.align(df,axis=1)

df2

Out[190]: 

   var1  var2  var3

0     4     5   NaN

1     1     7   NaN

2     3     7   NaN


查看完整回答
反对 回复 2022-01-05
?
慕慕森

TA贡献1856条经验 获得超17个赞

尝试使用reindex:


df2.reindex(df.columns, axis=1)

输出:


   var1  var2  var3

0     4     5   NaN

1     1     7   NaN

2     3     7   NaN


查看完整回答
反对 回复 2022-01-05
?
大话西游666

TA贡献1817条经验 获得超14个赞

 for n in (set(df.columns) - set(df2.columns)):
    df2[str(n)] = np.NaN


查看完整回答
反对 回复 2022-01-05
  • 3 回答
  • 0 关注
  • 139 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信