简体   繁体   English

如何将列添加到多索引DataFrame?

[英]How to add a column to a multi-indexed DataFrame?

I have a DataFrame like this: 我有一个像这样的DataFrame:

upper    level1    level2 
lower    name      name
1        Mary      Tom
2        ...       ...

What should I do if I want to add another column under level1 ? 如果我想在level1下添加另一列,我该怎么办? For example 例如

upper    level1       level2 
lower    name    age  name
1        Mary    13   Tom
2        ...    ...    ...

I can access data with df['level1'].loc[:,'name'] , but I don't know how to add/remove a column. 我可以使用df['level1'].loc[:,'name']访问数据,但我不知道如何添加/删除列。

If I just use df.level1['age']=1 , Python returns a copy warning and nothing changed in the DataFrame: 如果我只使用df.level1['age']=1 ,Python会返回一个复制警告,并且DataFrame中没有任何更改:

SettingWithCopyWarning: 
A value is trying to be set on a copy of a slice from a DataFrame.
Try using .loc[row_indexer,col_indexer] = value instead

See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy
if __name__ == '__main__':

尝试这个:

df.insert(1, ('level1', 'age'), pd.Series([13]))

You can use tuple in the assignment: 您可以在作业中使用元组:

In [11]: df[('level1', 'age')] = 13  # or a Series here, rather than a number

In [12]: df
Out[12]:
  upper level1 level2 level1
  lower   name   name    age
0     1   Mary    Tom     13
1     2    ...    ...     13

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

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