【100天精通Python】Day58:Python 数据分析_Pandas时间序列数据处理,创建和解析时间数据pd.to_datetime(),.loc[],resample() 用法示例

简介: 【100天精通Python】Day58:Python 数据分析_Pandas时间序列数据处理,创建和解析时间数据pd.to_datetime(),.loc[],resample() 用法示例

时间序列数据处理

       时间序列数据处理是数据科学和分析中的重要任务之一。Pandas 提供了丰富的功能来处理日期和时间数据、创建时间索引以及执行时间重采样。

  1. 创建时间序列数据:使用 Pandas 创建时间序列数据,通常需要包含日期时间列,并使用 pd.to_datetime() 将日期时间字符串转换为 Pandas 的日期时间对象。
  2. 时间索引:将日期时间列设置为数据框的索引,以便根据时间访问、分析和操作数据。
  3. 访问时间索引数据:使用 .loc[] 或切片语法来按年、月、日等级别访问数据,也可以使用属性(例如 .year.month.day)来访问索引的年、月、日等属性。
  4. 时间索引的切片:使用切片操作来选择特定时间范围内的数据,包括起始日期和结束日期。
  5. 时间索引的重采样:使用 resample() 方法将时间序列数据从一个频率转换为另一个频率,可以选择不同的频率,并应用不同的聚合函数(如 mean()sum()max()min() 等)来计算新频率下的值。

1. 解析日期和时间数据

       在 Pandas 中,你可以使用 pd.to_datetime() 函数将包含日期和时间的字符串解析为 Pandas 的日期时间对象。这允许你在数据中有效地处理日期和时间信息。

import pandas as pd
# 示例数据包含日期时间字符串
data = {'date': ['2023-09-01 08:00:00', '2023-09-02 09:30:00', '2023-09-03 10:45:00'],
        'value': [10, 15, 20]}
# 创建 DataFrame
df = pd.DataFrame(data)
# 解析日期列为日期时间对象
df['date'] = pd.to_datetime(df['date'])
# 查看结果
print(df)

输出结果:

2 创建时间索引

要在 Pandas 中创建时间索引,通常需要满足以下两个条件:

  • 数据框中必须包含日期时间列。
  • 使用 pd.to_datetime() 将日期时间列转换为 Pandas 的日期时间对象。

以下是一个示例,演示如何创建一个带有时间索引的数据框:

import pandas as pd
# 示例数据包含日期时间字符串
data = {'date': ['2023-09-01', '2023-09-02', '2023-09-03'],
        'value': [10, 15, 20]}
# 创建 DataFrame
df = pd.DataFrame(data)
# 解析日期列为日期时间对象
df['date'] = pd.to_datetime(df['date'])
# 将日期列设置为索引
df.set_index('date', inplace=True)
# 查看结果
print(df)

输出:

       在上述示例中,我们首先将日期字符串解析为 Pandas 的日期时间对象,然后使用 set_index() 方法将日期时间列设置为索引。

3. 访问时间索引数据

一旦创建了时间索引,你可以使用索引来访问数据,例如按日期、按月、按年等。

3.1 按年、月、日等级别访问数据 (.loc[])

假设你有一个时间索引的数据框 df,你可以使用 .loc[] 来按照不同级别访问数据。

import pandas as pd
import numpy as np
# 创建一个示例时间序列数据
date_rng = pd.date_range(start='2023-01-01', end='2023-12-31', freq='D')
data = {'value': np.random.randint(1, 100, len(date_rng))}
df = pd.DataFrame(data, index=date_rng)
# 访问特定年份的数据
print(df.loc['2023'])
# 访问特定月份的数据
print(df.loc['2023-03'])
# 访问特定日期的数据
print(df.loc['2023-06-15'])
# 访问某个时间范围内的数据
print(df.loc['2023-04-01':'2023-04-15'])

上述示例演示了如何按年、月、日等级别使用 .loc[] 访问数据。

3.2 使用部分日期作为索引 (.loc[ ], .loc[ : ])

如果你只关心时间索引的一部分,你可以使用部分日期来选择数据。

# 选择 2023 年 4 月的数据
print(df.loc['2023-04'])
# 选择 2023 年 5 月到 2023 年 8 月的数据
print(df.loc['2023-05':'2023-08'])
3.3 使用时间索引的属性 ( .index )

Pandas 还提供了 .index 属性,允许你访问时间索引的年、月、日等属性。

# 访问索引的年份
print(df.index.year)
# 访问索引的月份
print(df.index.month)
# 访问索引的日期
print(df.index.day)

输出如下:

       这些示例演示了如何按照不同的时间级别访问时间索引数据。时间索引的灵活性使你能够根据具体的需求轻松地选择和分析时间序列数据。

4 时间索引的切片

       时间索引的切片是一种非常有用的操作,它允许你选择时间序列数据中的特定时间范围。你可以使用 Pandas 中的 .loc[] 或直接使用时间索引的切片语法来执行时间索引的切片操作。以下是时间索引的切片示例:

import pandas as pd
import numpy as np
# 创建一个示例时间序列数据
date_rng = pd.date_range(start='2023-01-01', end='2023-12-31', freq='D')
data = {'value': np.random.randint(1, 100, len(date_rng))}
df = pd.DataFrame(data, index=date_rng)
# 使用 .loc[] 进行时间索引的切片
# 选择 2023 年 2 月到 2023 年 5 月的数据
subset1 = df.loc['2023-02-01':'2023-05-31']
# 选择 2023 年 8 月到 2023 年 10 月的数据
subset2 = df.loc['2023-08-01':'2023-10-31']
# 使用切片语法进行时间索引的切片
# 选择 2023 年 3 月到 2023 年 7 月的数据
subset3 = df['2023-03-01':'2023-07-31']
# 选择 2023 年 11 月到 2023 年 12 月的数据
subset4 = df['2023-11-01':]
# 查看结果
print(subset1,"subset1")
print(subset2,"subset2")
print(subset3,"subset3")
print(subset4,"subset4")

       在上述示例中,我们演示了两种不同的时间索引切片方法:一种使用 .loc[] 方法,另一种使用切片语法。无论使用哪种方法,都可以方便地选择特定的时间范围,以便进一步分析或可视化时间序列数据。

       请注意,时间索引的切片是包含起始日期和结束日期的。如果你想选择特定月份或年份的数据,也可以使用相应的索引,如 df['2023-02'] 或 df['2023']。

5 时间索引的重采样

        时间索引的重采样是一种将时间序列数据从一个频率转换为另一个频率的操作,例如将每小时数据转换为每天数据。

Pandas 提供了 resample() 方法来执行时间索引的重采样操作。以下是时间索引的重采样示例:

import pandas as pd
import numpy as np
# 创建一个示例时间序列数据,每小时一个数据点
date_rng = pd.date_range(start='2023-01-01', end='2023-01-05', freq='H')
data = {'value': np.random.randint(1, 100, len(date_rng))}
df = pd.DataFrame(data, index=date_rng)
# 按天重采样并计算每天的平均值
daily_mean = df.resample('D').mean()
# 按周重采样并计算每周的总和
weekly_sum = df.resample('W').sum()
# 按月重采样并计算每月的最大值
monthly_max = df.resample('M').max()
# 查看重采样结果
print("按天重采样:\n", daily_mean)
print("\n按周重采样:\n", weekly_sum)
print("\n按月重采样:\n", monthly_max)

输出如下:

目录
相关文章
|
7月前
|
数据采集 Web App开发 数据可视化
Python零基础爬取东方财富网股票行情数据指南
东方财富网数据稳定、反爬宽松,适合爬虫入门。本文详解使用Python抓取股票行情数据,涵盖请求发送、HTML解析、动态加载处理、代理IP切换及数据可视化,助你快速掌握金融数据爬取技能。
4246 1
|
7月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
511 2
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
1292 29
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
528 4
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
移动开发 前端开发 JavaScript
从入门到精通:H5游戏源码开发技术全解析与未来趋势洞察
H5游戏凭借其跨平台、易传播和开发成本低的优势,近年来发展迅猛。接下来,让我们深入了解 H5 游戏源码开发的技术教程以及未来的发展趋势。
|
存储 前端开发 JavaScript
在线教育网课系统源码开发指南:功能设计与技术实现深度解析
在线教育网课系统是近年来发展迅猛的教育形式的核心载体,具备用户管理、课程管理、教学互动、学习评估等功能。本文从功能和技术两方面解析其源码开发,涵盖前端(HTML5、CSS3、JavaScript等)、后端(Java、Python等)、流媒体及云计算技术,并强调安全性、稳定性和用户体验的重要性。
|
机器学习/深度学习 自然语言处理 算法
生成式 AI 大语言模型(LLMs)核心算法及源码解析:预训练篇
生成式 AI 大语言模型(LLMs)核心算法及源码解析:预训练篇
3808 1
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
创建型模式的主要关注点是“怎样创建对象?”,它的主要特点是"将对象的创建与使用分离”。这样可以降低系统的耦合度,使用者不需要关注对象的创建细节。创建型模式分为5种:单例模式、工厂方法模式抽象工厂式、原型模式、建造者模式。
1271 2
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析

推荐镜像

更多