首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Python pandas pivot_table多时间索引

Python pandas pivot_table多时间索引
EN

Stack Overflow用户
提问于 2020-01-23 05:15:43
回答 1查看 383关注 0票数 3

我有以下数据帧:

代码语言:javascript
复制
import pandas as pd
import datetime

df = pd.DataFrame({'T': [datetime.datetime.now(), datetime.datetime.now()], 'V': [1, 2]})

我想使用年和月作为索引进行透视,我可以这样做:

代码语言:javascript
复制
df.pivot_table(index = [df['T'].dt.year, df['T'].dt.month], values = 'V')

但是,因为这给了我两个名为T的列,所以我无法设置margins = True (抛出错误:The name T occurs multiple times, use a level number)。如何解决此问题?理想情况下,我希望在执行透视时手动命名列,这样我就有了YearMonth,而不是TT

有什么想法吗?

EN

Stack Overflow用户

回答已采纳

发布于 2020-01-23 05:19:53

IIUC,您可以使用rename重命名您的系列,

代码语言:javascript
复制
df.pivot_table(index = [df['T'].dt.year.rename('Year'),
                        df['T'].dt.month.rename('Month')], 
                values='V',
                aggfunc='sum', 
                margins=True)

输出:

代码语言:javascript
复制
              V
Year Month     
2020 1        3
All           3
票数 2
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59868363

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档