Pandas中日期时间字符串的正确转换与格式化

DDD
发布: 2025-10-26 09:01:30
原创
462人浏览过

Pandas中日期时间字符串的正确转换与格式化

本文详细介绍了如何在pandas dataframe中高效、准确地将日期时间字符串转换为datetime对象。重点讲解了使用`pd.to_datetime()`函数处理复杂日期时间格式(如包含毫秒)的方法,并强调了正确格式化字符串(特别是`%f`用于毫秒)的重要性,以避免常见的类型转换错误。文章还提供了示例代码和最佳实践,确保数据转换的准确性和健壮性。

在数据分析和处理中,将字符串形式的日期时间数据转换为可操作的datetime对象是常见的任务。尤其在使用Pandas DataFrame时,这种转换需要特别注意格式匹配和方法选择,以避免诸如“'str' object cannot be interpreted as an integer”之类的类型错误。本教程将深入探讨如何利用Pandas的强大功能,特别是pd.to_datetime(),来有效处理日期时间字符串转换。

挑战:日期时间字符串转换中的常见陷阱

当我们从CSV或其他数据源中读取日期时间数据时,它们通常以字符串形式存在。例如,一个常见的日期时间格式可能是 YY:MM:DD HH:MM:SS:MS,如 23:09:28 16:03:40:7。如果尝试使用Python标准库中的datetime.datetime函数直接处理DataFrame中的一列,并使用不完整的格式字符串(例如 %y:%m:%d %H:%M:%S 缺少毫秒部分),则很容易遇到以下问题:

  1. 格式字符串不匹配:如果字符串中包含毫秒(如 :7),而格式字符串中没有对应的 %f(微秒),则转换会失败。
  2. 类型错误:当尝试将一个包含非数字字符的字符串部分解释为整数时,Python会抛出 TypeError: 'str' object cannot be interpreted as an integer。这通常发生在格式字符串与实际数据不符,或者尝试将整个字符串传递给期望整数参数的位置时。
  3. 效率问题:对DataFrame中的每一行使用循环和datetime.datetime进行转换效率低下,不符合Pandas的向量化操作原则。

解决方案:使用 pd.to_datetime() 进行高效转换

Pandas提供了专门用于日期时间转换的函数 pd.to_datetime(),它能够高效地处理整个DataFrame列,并提供了灵活的格式化选项。

1. 核心函数:pd.to_datetime()

pd.to_datetime() 是将字符串、数字或datetime对象转换为Pandas datetime对象的首选方法。它具有以下优点:

  • 向量化操作:直接应用于整个Series或DataFrame列,性能远超逐行循环。
  • 智能推断:在不指定format参数时,可以尝试自动推断多种日期时间格式。
  • 错误处理:提供 errors 参数来控制如何处理无法解析的值。
  • 时区支持:可以方便地进行时区转换。

2. 正确指定格式字符串

解决日期时间转换问题的关键在于精确匹配日期时间字符串的格式。对于 YY:MM:DD HH:MM:SS:MS 这样的格式,其中 MS 代表毫秒,我们需要使用 %f 来匹配微秒(Python的 datetime 和 Pandas 的 to_datetime 都使用 %f 来表示微秒,即使输入是毫秒,也会被解析为微秒,例如 7 会被解析为 7000 微秒)。

下表列出了一些常用的格式代码:

代码 含义 示例
%y 两位数年份 23
%Y 四位数年份 2023
%m 月份(01-12) 09
%d 日期(01-31) 28
%H 小时(24小时制,00-23) 16
%M 分钟(00-59) 03
%S 秒(00-59) 40
%f 微秒(000000-999999) 7000 (对于输入7)

因此,对于 23:09:28 16:03:40:7 这样的字符串,正确的格式字符串应该是 "%y:%m:%d %H:%M:%S:%f"。

3. 示例代码

假设我们有一个Pandas DataFrame df,其中包含一个名为 RunStartTime 的列,其数据格式如前所述。

首先,我们创建一个示例DataFrame:

import pandas as pd
import numpy as np

# 创建一个示例DataFrame
data = {'RunStartTime': ['23:09:28 16:03:40:7', '23:10:01 09:15:22:123', '24:01:15 23:59:59:999']}
df = pd.DataFrame(data)

print("原始DataFrame:")
print(df)
print("\nRunStartTime 列的数据类型:", df['RunStartTime'].dtype)
登录后复制

输出:

吉卜力风格图片在线生成
吉卜力风格图片在线生成

将图片转换为吉卜力艺术风格的作品

吉卜力风格图片在线生成121
查看详情 吉卜力风格图片在线生成
原始DataFrame:
           RunStartTime
0   23:09:28 16:03:40:7
1  23:10:01 09:15:22:123
2  24:01:15 23:59:59:999

RunStartTime 列的数据类型: object
登录后复制

现在,使用 pd.to_datetime() 进行转换,并指定正确的格式字符串:

# 使用 pd.to_datetime() 转换日期时间字符串
# 注意:格式字符串中 %y 代表两位数年份,%f 代表微秒
df['RunStartTime_dt'] = pd.to_datetime(df['RunStartTime'], format="%y:%m:%d %H:%M:%S:%f")

print("\n转换后的DataFrame:")
print(df)
print("\nRunStartTime_dt 列的数据类型:", df['RunStartTime_dt'].dtype)
登录后复制

输出:

转换后的DataFrame:
           RunStartTime       RunStartTime_dt
0   23:09:28 16:03:40:7 2023-09-28 16:03:40.000007
1  23:10:01 09:15:22:123 2023-10-01 09:15:22.000123
2  24:01:15 23:59:59:999 2020-01-15 23:59:59.000999

RunStartTime_dt 列的数据类型: datetime64[ns]
登录后复制

可以看到,RunStartTime_dt 列已成功转换为 datetime64[ns] 类型,并且毫秒部分也得到了正确解析。

4. 仅获取日期部分

如果只需要日期部分,而不需要时间信息,可以使用 .dt.normalize() 方法。这个方法会将时间部分设置为午夜(00:00:00)。

# 仅获取日期部分
df['date_only'] = df['RunStartTime_dt'].dt.normalize()

print("\n仅包含日期部分的DataFrame:")
print(df)
print("\ndate_only 列的数据类型:", df['date_only'].dtype)
登录后复制

输出:

仅包含日期部分的DataFrame:
           RunStartTime       RunStartTime_dt  date_only
0   23:09:28 16:03:40:7 2023-09-28 16:03:40.000007 2023-09-28
1  23:10:01 09:15:22:123 2023-10-01 09:15:22.000123 2023-10-01
2  24:01:15 23:59:59:999 2020-01-15 23:59:59.000999 2020-01-15

date_only 列的数据类型: datetime64[ns]
登录后复制

虽然 date_only 列的数据类型仍然是 datetime64[ns],但其时间部分已被归一化为 00:00:00。

注意事项与最佳实践

  1. 处理无法解析的值:如果数据中可能存在无法解析的日期时间字符串,可以使用 errors 参数:

    • errors='raise' (默认):遇到错误时抛出异常。
    • errors='coerce':将无法解析的值转换为 NaT (Not a Time)。这在处理脏数据时非常有用。
    • errors='ignore':保留原始无法解析的值。
    df_err = pd.DataFrame({'time_str': ['23:09:28 16:03:40:7', 'invalid_date', '24:01:15 23:59:59:999']})
    df_err['parsed_time'] = pd.to_datetime(df_err['time_str'], format="%y:%m:%d %H:%M:%S:%f", errors='coerce')
    print("\n处理错误值的DataFrame:")
    print(df_err)
    登录后复制

    输出:

    处理错误值的DataFrame:
              time_str               parsed_time
    0  23:09:28 16:03:40:7 2023-09-28 16:03:40.000007
    1         invalid_date                      NaT
    2  24:01:15 23:59:59:999 2020-01-15 23:59:59.000999
    登录后复制
  2. 性能优化

    • 如果日期时间格式是固定的,始终指定 format 参数。这会显著提高解析速度,因为Pandas不需要尝试多种格式进行推断。
    • 如果日期时间格式不固定但数量有限且有规律,可以尝试设置 infer_datetime_format=True。这会告诉Pandas尝试推断格式,并且在成功推断后,对于后续的相同格式字符串会加速解析。但在极端情况下,如果格式非常混乱,它可能会比指定 format 慢。
  3. 提取日期时间组件:一旦列被转换为 datetime64[ns] 类型,就可以使用 .dt 访问器来方便地提取年、月、日、小时等组件:

    print("\n提取日期时间组件:")
    print("年份:", df['RunStartTime_dt'].dt.year)
    print("月份:", df['RunStartTime_dt'].dt.month)
    print("日期:", df['RunStartTime_dt'].dt.day)
    print("小时:", df['RunStartTime_dt'].dt.hour)
    print("毫秒 (原始微秒除以1000):", df['RunStartTime_dt'].dt.microsecond / 1000)
    登录后复制

    输出:

    提取日期时间组件:
    年份: 0    2023
    1    2023
    2    2020
    Name: RunStartTime_dt, dtype: int64
    月份: 0    9
    1    10
    2     1
    Name: RunStartTime_dt, dtype: int64
    日期: 0    28
    1     1
    2    15
    Name: RunStartTime_dt, dtype: int64
    小时: 0    16
    1     9
    2    23
    Name: RunStartTime_dt, dtype: int64
    毫秒 (原始微秒除以1000): 0      7.0
    1    123.0
    2    999.0
    Name: RunStartTime_dt, dtype: float64
    登录后复制

总结

在Pandas中处理日期时间字符串时,pd.to_datetime() 是一个不可或缺的工具。通过正确理解和使用 format 参数,特别是针对包含毫秒的字符串使用 %f,可以高效且准确地将字符串数据转换为可操作的datetime对象。同时,利用 errors='coerce' 进行健壮性处理,以及 .dt 访问器提取日期时间组件,将极大地提升数据清洗和分析的效率。遵循这些最佳实践,可以避免常见的转换错误,并确保日期时间数据的完整性和可用性。

以上就是Pandas中日期时间字符串的正确转换与格式化的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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