PythonPandas数据分析项目教程_时间序列透视表应用
技术百科
冷漠man
发布时间:2026-01-01
浏览: 次 时间序列透视表需先将时间列转为datetime类型,再用pd.Grouper按频率(如'M'、'Q')分组或dt访问器提取年/季等字段,最后用pivot_table聚合;缺失周期需resample或date_range补全。
时间序列透视表在Pandas中不是独立功能,而是通过pd.pivot_table()结合时间列(如日期)的预处理(如dt.year、dt.month、pd.Grouper)实现的。关键在于把时间维度“结构化”为可分组的类别或规则频率,再按需聚合。
用pd.Grouper按时间频率自动分组
这是最简洁、最推荐的方式,尤其适合原始数据含DatetimeIndex或已转为datetime类型的列。
- 先确保时间列为
datetime类型:df['date'] = pd.to_datetime(df['date']) - 设为索引后使用
pd.Grouper:df.set_index('date').pivot_table(values='sales', index=pd.Grouper(freq='M'), columns='region', aggfunc='sum')——按月汇总各地区销售额 - 支持常用频率:
'D'(日)、'W'(周)、'M'(月末)、'MS'(月初)、'Q'(季度)、'A'(年度)
用dt访问器提取年/月/日等离散字段
适合需要组合多个时间层级(如“2025年华东Q1”),或时间列不便设索引时。
- 添加新列:
df['year'] = df['date'].dt.year,df['quarter'] = df['date'].dt.quarter - 直接用于
pivot_table:pd.pivot_table(df, values='revenue', index='year', columns=['region', 'quarter'], aggfunc='mean') - 注意:
dt.quarter返回1–4整数,可配合map转为'Q1'/'Q2'等标签提升可读性
处理非规则时间点与缺失周期
原始数据可能跳过某些日期(如节假日无记录),默认透视表不会补全空周期,需手动对齐。
- 用
resample()先重采样再聚合(适用于时间索引):df.set_index('date').resample('MS').sum().reset_index(),再做透视 - 或用
pd.date_range()生成完整时间序列,reindex()补零:full_idx = pd.date_range(start='2025-01-01', end='2025-12-31', freq='MS'),再groupby后reindex(full_idx, fill_value=0) - 透视表本身不插值,补全逻辑应在
pivot_table调用前完成
多级
时间索引与动态列名
当需同时观察年份和月份、或按工作日/周末分类时,可构建复合时间维度。
- 新增列组合:
df['year_month'] = df['date'].dt.to_period('M')(生成Period类型,天然支持排序和对齐) - 或用
cut()划分时间区间:df['period'] = pd.cut(df['date'].astype('int64'), bins=[start_ts, mid_ts, end_ts], labels=['H1', 'H2']) - 列名可动态生成:
columns=pd.Grouper(key='date', freq='2W'),让每两周自动成一列
# 这是
# 数据分析
# 多个
# python
# 适用于
# 设为
# 再用
# map
# 访问器
# date
# 或用
# pandas
# 原始数据
# 月末
# 应在
# 两周
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- 如何在 ACF 中正确更新嵌套多层的 Group
- Linux如何使用grep搜索文件内容_Linux
- Win11怎么关闭系统推荐内容_Windows11
- Win11怎么连接投影仪_Win11多显示器投屏设
- Win11怎么开启智能存储_Windows11存储
- Win11怎么设置快速访问_Windows11文件
- Python数据抓取合法性_合规说明【指导】
- Win11怎么开启HDR模式_Windows 11
- c# Task.ConfigureAwait(tr
- 如何使用正则表达式批量替换重复的 *- 模式为固定
- php485读数据时阻塞怎么办_php485非阻塞
- php下载安装后memory_limit怎么设置_
- MAC如何启用访达侧边栏显示_MAC Finder
- Windows怎样拦截QQ浏览器广告_Window
- MAC的“接续互通”功能无法使用怎么办_MAC检查
- Win11怎么开启剪贴板历史记录_Windows1
- PHP主流架构如何处理会话管理_Session与C
- 如何使用Golang处理网络超时错误_Golang
- php能跑在stm32上吗_php在stm32微控
- Python抽象类与接口设计_规范说明【指导】
- Windows电脑如何截屏?(四种快捷方法)
- Win10怎样安装PPT模板_Win10安装PPT
- 本地php环境出现502错误_nginx或apac
- php订单日志怎么按状态筛选_php筛选不同状态订
- C++如何使用std::transform批量处理
- Win11怎么更改系统语言为中文_Windows1
- XSLT怎么生成动态的HTML属性名和标签名
- Win11怎么设置开机问候语_自定义Win11锁屏
- PHP主流架构怎么处理表单验证_规则与自定义【技巧
- Win11怎么格式化U盘_Win11系统U盘格式化
- Python文件操作优化_大文件与流处理解析【教程
- php修改数据怎么批量改状态_批量更新status
- Win11任务栏怎么放到顶部_Win11修改任务栏
- Win11系统更新后黑屏怎么办 Win11更新黑屏
- Win11怎样彻底卸载自带应用_Win11彻底卸载
- Win11怎么更改电脑密码_Windows 11修
- 一文教你快速开通网站LOGO图
- 如何使用Golang指针与接口结合_实现方法调用和
- PHP接收参数值为空怎么办_判断和处理空参数方法说
- php错误怎么开启_display_errors与
- Win10系统怎么查看显卡温度_Win10任务管理
- Win11用户账户控制怎么关_Win11关闭UAC
- Win11怎么退出微软账户_切换Win11为本地账
- 如何在 Go 中可靠地测试含 time.Time
- Python随机数生成_random模块说明【指导
- 如何自定义Windows终端的默认配置文件?(Po
- c++如何使用std::bind绑定函数参数_c+
- Win11怎么关闭任务栏小组件_Windows11
- 如何使用Golang实现聊天室消息存档_存储聊天记
- Python性能剖析高级教程_cProfileLi

时间索引与动态列名
QQ客服