我真的懂索引吗?——groupby、resample结果无法输出,重新设置索引reset_index

关键字:Pandas,groupby,resample
结果,列名,表头,多层,错行,多行
重新设置索引,索引转换为数据

一直很难描述这个问题,陆陆续续困扰了好久
dataframe格式数据,经过groupby、resample等操作后
结果显示表头(列名)不止一行
在这里插入图片描述
想把前2列也作为结果记录到数据库,或者读取整行4个字段信息,一直没有好的办法

在网上找了这些问题
1、dataframe表头多行,列名多行,
2、dataframe多层列名,多层表头
3、列名错行、表头错行、标题错行
4、dataframe groupby,resample后保存
5、dataframe groupby,resample后第一行为空

这应该是一个高手沉默,小白流泪的问题了。。。
没人带路真的要走好多弯路

直到我慢慢意识到,前2列应该是索引
那么问题就转成了,索引能不能转换为数据?或者能不能重新设置索引?
重设索引?
重设索引我会啊!

df= df.reset_index()
# .reset_index()函数

难道就这么简单?输出看看:
在这里插入图片描述
世界安静了有木有!!!
整个人都好了有木有!!!
经常写的reset_index()居然有这个效果!!!
原因就是我不知道前两列原来就叫:“索引”。。。
送给和我一样彷徨过的朋友们,good luck

另一个方法:
df.groupby(‘books’, as_index=False).sum()
可以对比一下as_index=True的区别

grouby(by=None, axis=0, level=None, as_index=True, sort=True, group_keys=True, squeeze=False, **kwargs)
参考文献:https://pandas.pydata.org/docs/reference/api/pandas.DataFrame.groupby.html#pandas.DataFrame.groupby

附录:
reset_index()
函数原型:DataFrame.reset_index(level=None, drop=False, inplace=False, col_level=0, col_fill=’’)
参数解释:
level:int、str、tuple或list,默认无,仅从索引中删除给定级别。默认情况下移除所有级别。控制了具体要还原的那个等级的索引
drop:drop为False则索引列会被还原为普通列,否则会丢失
inplace:默认为false,适当修改DataFrame(不要创建新对象)
col_level:int或str,默认值为0,如果列有多个级别,则确定将标签插入到哪个级别。默认情况下,它将插入到第一级。
col_fill:对象,默认‘’,如果列有多个级别,则确定其他级别的命名方式。如果没有,则重复索引名
注:reset_index还原分为两种类型,第一种是对原DataFrame进行reset,第二种是对使用过set_index()函数的DataFrame进行reset

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

779醒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值