按照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表示年份。

相关内容

热门资讯

2分钟普及!乐酷辅助,约战平台... 2分钟普及!乐酷辅助,约战平台辅助(本来是真的挂)-哔哩哔哩1、超多福利:超高返利,海量正版游戏,约...
3分钟总结!新悠悠辅助微信,心... 3分钟总结!新悠悠辅助微信,心悦填大坑辅助(真是有挂)-哔哩哔哩1、进入游戏-大厅左侧-新手福利-激...
第三分钟教你!微信小程序开心泉... 第三分钟教你!微信小程序开心泉州辅助器,拱趴大菠萝修改器(切实真的有挂)-哔哩哔哩1、第三分钟教你!...
2分钟揭露!浙江游戏大厅修改数... 2分钟揭露!浙江游戏大厅修改数据,欢乐茶馆辅助(一直是真的挂)-哔哩哔哩1、该软件可以轻松地帮助玩家...
第1分钟曝光!皮皮透视辅助软件... 第1分钟曝光!皮皮透视辅助软件工具,决战卡五星必赢神器(一直真的有挂)-哔哩哔哩1、进入到皮皮透视辅...
两分钟揭幕!金虎爷有挂吗,新天... 两分钟揭幕!金虎爷有挂吗,新天道辅助(真是存在有挂)-哔哩哔哩金虎爷有挂吗辅助器中分为三种模型:金虎...
两分钟科普!九酷互娱辅助,微乐... 两分钟科普!九酷互娱辅助,微乐陕西小程序破解器(真是真的是有挂)-哔哩哔哩亲,关键说明,微乐陕西小程...
第四分钟解密!填大坑小程序辅助... 第四分钟解密!填大坑小程序辅助器,新九哥开挂(都是真的是有挂)-哔哩哔哩1、完成填大坑小程序辅助器透...
两分钟详细!微信小程序多乐辅助... 两分钟详细!微信小程序多乐辅助器,新悠悠辅助(果然是有挂)-哔哩哔哩1、微信小程序多乐辅助器系统规律...
七分钟外挂!宝宝浙江游戏开挂器... 七分钟外挂!宝宝浙江游戏开挂器,潮汕汇辅助神器(真是是真的挂)-哔哩哔哩1、宝宝浙江游戏开挂器系统规...