0

0

使用Pandas创建按半年间隔分组的数据透视表

花韻仙語

花韻仙語

发布时间:2025-10-24 13:20:04

|

523人浏览过

|

来源于php中文网

原创

使用Pandas创建按半年间隔分组的数据透视表

本文详细介绍了如何利用pandas库创建按半年(上半年/下半年)间隔分组的数据透视表,而非传统的按年分组。通过结合年份和月份条件判断,实现自定义的时间周期聚合,并进一步演示了如何将生成的多级索引转换回标准的日期格式,以提高数据分析和可视化的灵活性。

引言

在数据分析中,我们经常需要对时间序列数据进行聚合和汇总。Pandas的pivot_table功能非常强大,可以方便地按年、季度、月等标准时间单位进行分组。然而,在某些业务场景下,我们可能需要更灵活的自定义时间间隔,例如按半年(上半年H1、下半年H2)进行数据汇总。本文将详细讲解如何实现这一需求,并提供将自定义索引转换回日期格式的方法。

准备示例数据

首先,我们创建一个包含日期索引和随机数据的Pandas DataFrame作为示例。为了与问题描述保持一致,我们还添加了一个Vessel列,用于在数据透视表中作为列。

import pandas as pd
import numpy as np

# 创建日期范围从2023年1月1日到2024年1月5日
date_rng = pd.date_range(start='2023-01-01', end='2024-01-05', freq='D')
# 生成随机数据
data = np.random.rand(len(date_rng), 3)
df = pd.DataFrame(data, columns=['Column1', 'Column2', 'Column3'], index=date_rng)

# 添加Vessel列,用于数据透视表的列
df["Vessel"] = np.random.randint(1, 5, size=len(date_rng))

print("原始DataFrame的前5行:")
print(df.head())

创建按半年间隔分组的数据透视表

要实现按半年间隔分组,我们需要在pivot_table的index参数中提供一个包含年份和半年标识符的列表。年份可以直接通过df.index.year获取。半年的标识符(H1或H2)可以通过判断月份是否小于等于6来生成。这里我们使用numpy.where函数进行条件判断:如果月份小于等于6,则为"H1"(上半年),否则为"H2"(下半年)。

# 使用pivot_table创建按半年间隔分组的数据透视表
pivot_df = pd.pivot_table(
    df,
    index=[df.index.year, np.where(df.index.month <= 6, "H1", "H2")], # 关键:自定义索引
    columns="Vessel",
    values=["Column1", "Column2", "Column3"],
    aggfunc="nunique", # 聚合函数,计算唯一值的数量
)

print("\n按半年间隔分组的数据透视表:")
print(pivot_df)

输出示例:

        Column1                   Column2                   Column3                  
Vessel        1     2     3     4       1     2     3     4       1     2     3     4
2023 H1    39.0  41.0  59.0  42.0    39.0  41.0  59.0  42.0    39.0  41.0  59.0  42.0
     H2    43.0  53.0  34.0  54.0    43.0  53.0  34.0  54.0    43.0  53.0  34.0  54.0
2024 H1     NaN   1.0   3.0   1.0     NaN   1.0   3.0   1.0     NaN   1.0   3.0   1.0

从输出可以看出,数据透视表的索引现在是多级的,第一级是年份,第二级是半年标识符(H1或H2),清晰地展示了每个半年内各Vessel的Column1、Column2、Column3的唯一值数量。

星辰Agent
星辰Agent

科大讯飞推出的智能体Agent开发平台,助力开发者快速搭建生产级智能体

下载

将索引转换回日期格式

虽然多级索引在某些情况下很有用,但在进行时间序列分析或可视化时,我们可能更倾向于使用标准的日期索引。我们可以通过遍历当前的年和半年标识符,并根据半年标识符构建对应的日期(例如,H1对应当年1月1日,H2对应当年7月1日),然后将其转换回datetime对象。

# 将数据透视表的索引转换回日期格式
pivot_df.index = [
    pd.to_datetime(f'{year}-{"01-01" if half == "H1" else "07-01"}') # 注意:H2通常从7月1日开始
    for year, half in pivot_df.index
]

print("\n索引转换为日期格式后的数据透视表:")
print(pivot_df)

输出示例:

           Column1                   Column2                   Column3                  
Vessel           1     2     3     4       1     2     3     4       1     2     3     4
2023-01-01    48.0  44.0  43.0  46.0    48.0  44.0  43.0  46.0    48.0  44.0  43.0  46.0
2023-07-01    49.0  41.0  48.0  46.0    49.0  41.0  48.0  46.0    49.0  41.0  48.0  46.0
2024-01-01     1.0   1.0   NaN   3.0     1.0   1.0   NaN   3.0     1.0   1.0   NaN   3.0

现在,数据透视表的索引已经变为了标准的日期格式,更便于后续的时间序列操作和分析。

注意事项

  1. 自定义逻辑的灵活性: np.where的条件判断是实现自定义分组的关键。你可以根据具体需求调整条件,例如创建季度、双月、甚至更复杂的时间段分组。
  2. 聚合函数 aggfunc参数可以接受多种聚合函数,如sum、mean、count、min、max,甚至自定义函数。在本例中,我们使用了nunique来计算唯一值的数量。
  3. 缺失值处理: 在数据透视表的结果中可能会出现NaN值,这表示在特定分组和列组合下没有数据。在实际应用中,你可能需要使用fillna()等方法进行缺失值处理。
  4. 索引转换的起始日期: 在将半年索引转换回日期时,H1通常对应1月1日,H2通常对应7月1日。请根据你的业务定义调整这些起始日期。

总结

本文演示了如何使用Pandas pivot_table结合numpy.where和日期时间属性,灵活地创建按半年间隔分组的数据透视表。这种方法不仅解决了按自定义时间间隔聚合数据的需求,还提供了将多级索引转换回标准日期格式的方案,极大地增强了Pandas在时间序列数据分析中的应用能力。掌握这种技巧,将使你在处理复杂时间维度的数据时更加得心应手。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

53

2025.12.04

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

182

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

282

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

255

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

121

2025.08.07

数据分析的方法
数据分析的方法

数据分析的方法有:对比分析法,分组分析法,预测分析法,漏斗分析法,AB测试分析法,象限分析法,公式拆解法,可行域分析法,二八分析法,假设性分析法。php中文网为大家带来了数据分析的相关知识、以及相关文章等内容。

469

2023.07.04

数据分析方法有哪几种
数据分析方法有哪几种

数据分析方法有:1、描述性统计分析;2、探索性数据分析;3、假设检验;4、回归分析;5、聚类分析。本专题为大家提供数据分析方法的相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.08.07

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

8

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 12.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

NumPy 教程
NumPy 教程

共44课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号