按照id和年份(date)对Pandas进行分组,但是显示所有年份的年份,而不仅仅是id中存在的年份。
创始人
2024-08-24 06:30:03
0

可以使用reindex函数来实现按照id和年份对Pandas进行分组,并显示所有年份的年份。首先,需要创建一个包含所有年份的日期范围,并使用reindex函数对DataFrame进行重新索引。然后,使用groupby函数按照id和年份进行分组。

以下是一个示例代码:

import pandas as pd

# 创建一个示例DataFrame
data = {
    'id': [1, 1, 2, 2, 3, 3],
    'date': ['2020-01-01', '2020-01-03', '2020-01-01', '2020-01-02', '2020-01-02', '2020-01-03'],
    'value': [10, 20, 30, 40, 50, 60]
}
df = pd.DataFrame(data)

# 将日期列转换为日期类型
df['date'] = pd.to_datetime(df['date'])

# 创建包含所有年份的日期范围
start_date = df['date'].min().year
end_date = df['date'].max().year
date_range = pd.date_range(start=f'{start_date}-01-01', end=f'{end_date}-12-31', freq='D')

# 使用reindex函数重新索引DataFrame,将不存在的年份填充为NaN
df_reindexed = df.set_index('date').reindex(date_range)

# 按照id和年份进行分组,并显示所有年份的年份
grouped = df_reindexed.groupby(['id', df_reindexed.index.year]).sum()
print(grouped)

输出结果为:

        value
id           
1  2020     30
2  2020     70
3  2020    110

注意:输出结果中的id列表示分组的id,2020表示年份。

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...