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

相关内容

热门资讯

第三分钟了解!小闲川南手游辅助... 第三分钟了解!小闲川南手游辅助器!原来真的是有辅助脚本(揭秘有挂)-哔哩哔哩1、玩家可以在小闲川南手...
第6分钟了解!波特互娱辅助!其... 第6分钟了解!波特互娱辅助!其实一直总是有辅助方法(新版有挂)-哔哩哔哩;第6分钟了解!波特互娱辅助...
第三分钟了解!微乐小程序辅助教... 第三分钟了解!微乐小程序辅助教程!其实有辅助攻略(有挂总结)-哔哩哔哩1、这是跨平台的微乐小程序辅助...
一分钟了解!789大菠萝攻略!... 一分钟了解!789大菠萝攻略!确实是有辅助脚本(真的有挂)-哔哩哔哩789大菠萝攻略破解侠是真的助透...
第5分钟了解!微信十三张脚本!... 第5分钟了解!微信十三张脚本!切实一直总是有辅助方法(确实有挂)-哔哩哔哩一、微信十三张脚本可以开透...
八分钟了解!心悦填大坑技巧分析... 八分钟了解!心悦填大坑技巧分析器!其实真的有辅助插件(有挂方式)-哔哩哔哩1、实时心悦填大坑技巧分析...
第一分钟了解!中至上饶麻将有挂... 第一分钟了解!中至上饶麻将有挂开挂!其实有辅助插件(真的有挂)-哔哩哔哩运中至上饶麻将有挂开挂辅助工...
第二分钟了解!微信神兽大厅源代... 第二分钟了解!微信神兽大厅源代码!总是一直都是有辅助脚本(有挂头条)-哔哩哔哩1、不需要AI权限,帮...
八分钟了解!wepkerplu... 八分钟了解!wepkerplus辅助作弊!确实存在有辅助app(有挂规律)-哔哩哔哩该软件可以轻松地...
第4分钟了解!小程序66徐州辅... 第4分钟了解!小程序66徐州辅助!一贯是有辅助软件(有挂教程)-哔哩哔哩1、操作简单,无需小程序66...