0

0

如何正确将含时间戳的 Excel 文件导入 Pandas DataFrame

花韻仙語

花韻仙語

发布时间:2026-02-27 11:02:04

|

634人浏览过

|

来源于php中文网

原创

如何正确将含时间戳的 Excel 文件导入 Pandas DataFrame

本文详解如何在使用 pandas.read_excel() 导入 Excel 数据时,准确解析 "m/d/Y H:M" 格式的时间戳列,避免因区域设置或 Excel 自动格式推断导致的日期错乱(如 1/5/2021 被误读为 2021-01-05 而非 2021-05-01),并提供可靠、可复现的解决方案。

本文详解如何在使用 `pandas.read_excel()` 导入 excel 数据时,准确解析 `"m/d/y h:m"` 格式的时间戳列,避免因区域设置或 excel 自动格式推断导致的日期错乱(如 `1/5/2021` 被误读为 `2021-01-05` 而非 `2021-05-01`),并提供可靠、可复现的解决方案。

在处理水文、气象或工业传感器等时序数据时,Excel 文件中常以 m/d/Y H:M(如 4/30/2021 23:45)格式存储时间戳。但 pandas.read_excel() 默认不强制按指定格式解析日期列——它依赖 Excel 文件中单元格的底层数值类型(如 Excel 序列号)及 date_format 参数(该参数仅对 Excel 原生日期类型生效,对文本型日期无效),因此极易出现日期错位:当月份数 ≤12 时(如 1/5/2021),Pandas 可能错误地将其解释为 2021-01-05(日/月/年),而非预期的 2021-05-01(月/日/年)。

根本原因在于:Excel 文件中的“日期”若实际以纯文本形式存储(而非 Excel 的日期序列值),read_excel() 会将其读为 object 类型字符串,此时 parse_dates 和 date_format 参数均不会生效。这也是用户尝试 parse_dates=[2], date_format="%m/%d/%Y %H:%M:%S" 却未奏效的关键原因。

✅ 正确做法是:先完整读取数据,再对字符串日期列显式调用 pd.to_datetime() 并指定精确格式。该方法完全绕过 Excel 解析逻辑,直接控制字符串到 datetime 的转换过程,鲁棒性强、行为可预测。

以下为推荐代码实现:

提客AI提词器
提客AI提词器

「直播、录课」智能AI提词,搭配抖音直播伴侣、腾讯会议、钉钉、飞书、录课等软件等任意软件。

下载
import pandas as pd

# 1. 无解析地读取 Excel(确保 date 列作为字符串读入)
df = pd.read_excel("DATA.xlsx", dtype={"date": "string"})  # 或省略 dtype,让 pandas 自动推断为 object

# 2. 显式按 '%m/%d/%Y %H:%M' 格式转换(注意:秒位缺失时勿加 :%S)
df["date"] = pd.to_datetime(df["date"], format="%m/%d/%Y %H:%M")

# 3. 验证结果
print(df.dtypes)
print(df.head())

输出示例:

date          datetime64[ns]
flowrate             float64
dtype: object

                 date  flowrate
0 2021-04-30 23:45:00   -1904.39
1 2021-04-30 23:50:00   -1864.59
2 2021-04-30 23:55:00   -1772.78
3 2021-01-05 00:00:00   -1679.54  # 注意:此处 1/5/2021 → 2021-01-05(符合 m/d/Y)

⚠️ 关键注意事项:

  • 格式字符串必须严格匹配原始文本:若 Excel 中时间为 4/30/2021 23:45(无秒),则 format 必须为 "%m/%d/%Y %H:%M";若含秒(如 4/30/2021 23:45:30),才使用 "%m/%d/%Y %H:%M:%S"。
  • 避免 infer_datetime_format=True:该参数会启用启发式推断,在混合格式(如前12行是 m/d/Y,后续变为 d/m/Y)下极易失败,应始终显式指定 format。
  • 处理异常值:若数据中存在格式不一致的脏数据(如空值、拼写错误),可添加 errors="coerce" 将其转为 NaT:
    df["date"] = pd.to_datetime(df["date"], format="%m/%d/%Y %H:%M", errors="coerce")
  • 性能提示:对超大 Excel 文件,建议优先导出为 CSV(文本格式更可控),再用 pd.read_csv() + 相同 pd.to_datetime() 流程处理,速度更快且解析更稳定(正如提问者最终采用的方案)。

总结:解决 Excel 时间戳导入错乱的核心原则是——放弃依赖 read_excel() 的自动日期解析,改用 pd.to_datetime() 在内存中精准控制转换逻辑。这一模式不仅适用于 m/d/Y 场景,也适用于任何自定义日期格式(如 Y-m-d H.M.S、d-b-Y 等),是生产环境中最可靠、最易维护的实践方案。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

76

2025.12.04

Python 数据清洗与预处理实战
Python 数据清洗与预处理实战

本专题系统讲解 Python 在数据清洗与预处理中的核心技术,包括使用 Pandas 进行缺失值处理、异常值检测、数据格式化、特征工程与数据转换,结合 NumPy 高效处理大规模数据。通过实战案例,帮助学习者掌握 如何处理混乱、不完整数据,为后续数据分析与机器学习模型训练打下坚实基础。

10

2026.01.31

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

866

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

453

2024.06.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1560

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

643

2023.11.24

html5播放器怎么用
html5播放器怎么用

本合集全面介绍HTML5播放器的使用方法,涵盖基础语法、自定义控制、兼容性处理及实战示例。阅读专题下面的文章了解更多详细内容。

0

2026.02.27

热门下载

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

精品课程

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

共162课时 | 19万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

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

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