pandas里怎么把有multiindex的列拉平变成一层?

  统计/机器学习 Python    浏览次数:2594        分享
0

上面这个dataframe的columns是multiindex的,打印列名

df.columns

得到

MultiIndex(levels=[['value', 'date', 'id'], ['max', 'min', '']],
           codes=[[2, 1, 0, 0], [2, 2, 0, 1]])

我想得到扁平化的列明,比如上面最后就只有四列,分别是

['id', 'date', 'value_max', 'value_min']

求助各位, 谢谢~

 

R琳   2019-09-24 03:45



   1个回答 
2


df.columns = ['_'.join(col).rstrip('_') for col in df.columns.values]

新的列明就是['id', 'date', 'value_max', 'value_min']

SofaSofa数据科学社区DS面试题库 DS面经

LiShanfei   2019-09-24 07:17

试过了,果然可以了,谢谢! - R琳   2019-09-24 09:41


  相关主题

怎么删除pandas dataframe中index重复的行?   2回答

怎么利用pandas获得一个列联表(contingency table)?   1回答

pandas读取csv文件遇到UnicodeDecodeError   2回答

怎么删除pandas数据框指定的第k行?   2回答

怎么按照index对pd.DataFrame的行排序?   1回答

pandas中某列中数字后边有 亿/万这种单位 如何处理   1回答

统计substring在pandas dataframe中一列文本中出现的次数?   1回答

找到pd.DataFrame中某个列名对应的下标?   1回答

怎么利用pandas新建一个只有列名的空的dataframe?   1回答

怎么改变pandas dataframe里column的顺序?   1回答

怎么把一个pandas数据框用append的方式添加到现有的csv文件?   2回答

pandas里index的问题   1回答



回答问题时需要注意什么?

我们谢绝在回答前讲“生动”的故事。

我们谢绝“这么简单,你自己想”、“书上有的,你认真看”这类的回答;如果你认为对方的提问方式或者内容不妥,你可以直接忽略该问题,不用进行任何作答,甚至可以对该问题投反对票。

我们谢绝答非所问。

我们谢绝自己不会、硬要回答。

我们感激每一个用户在编写答案时的努力与付出!