Python字符串转datetime方法详解
本篇文章给大家分享《Python如何将字符串转为datetime对象》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
使用datetime.strptime()可将字符串转为datetime对象,需确保格式代码与字符串严格匹配,如%Y-%m-%d对应"2023-10-27";对不同时区或模糊格式,可借助dateutil.parser.parse或fromisoformat()处理,并建议内部统一用UTC时间。
在Python中,将字符串转换为datetime
对象,核心在于datetime
模块提供的strptime()
方法。这个方法就像一个翻译官,它能理解你给出的日期时间字符串的“语言(格式)”,并将其准确地解析成Python能够处理的datetime
类型。理解并正确使用格式代码是关键,一旦格式对不上,它就会直接报错,毫不留情。
解决方案
要将字符串转换为datetime
对象,你需要使用datetime
模块中的datetime.strptime(date_string, format)
函数。
date_string
:这是你要转换的日期时间字符串。format
:这是一个格式字符串,它告诉strptime()
如何解析date_string
。这个格式字符串由各种“格式代码”组成,比如%Y
代表四位数的年份,%m
代表两位数的月份,%d
代表两位数的日期等等。
基本示例:
from datetime import datetime # 示例1: 常见的日期时间格式 date_str_1 = "2023-10-27 14:30:00" # 对应的格式字符串:%Y (年)-%m (月)-%d (日) %H (小时):%M (分钟):%S (秒) dt_object_1 = datetime.strptime(date_str_1, "%Y-%m-%d %H:%M:%S") print(f"字符串 '{date_str_1}' 转换为: {dt_object_1}, 类型: {type(dt_object_1)}") # 示例2: 只有日期 date_str_2 = "2023/10/27" # 对应的格式字符串:%Y (年)/%m (月)/%d (日) dt_object_2 = datetime.strptime(date_str_2, "%Y/%m/%d") print(f"字符串 '{date_str_2}' 转换为: {dt_object_2}, 类型: {type(dt_object_2)}") # 示例3: 包含毫秒(注意:strptime对毫秒的支持有限,通常需要手动处理) # 如果字符串是 "2023-10-27 14:30:00.123",%f 可以解析微秒 date_str_3 = "2023-10-27 14:30:00.123456" dt_object_3 = datetime.strptime(date_str_3, "%Y-%m-%d %H:%M:%S.%f") print(f"字符串 '{date_str_3}' 转换为: {dt_object_3}, 类型: {type(dt_object_3)}") # 示例4: ISO 8601 格式,通常推荐使用 fromisoformat() # 但 strptime 也能处理 date_str_4 = "2023-10-27T14:30:00" dt_object_4 = datetime.strptime(date_str_4, "%Y-%m-%dT%H:%M:%S") print(f"字符串 '{date_str_4}' 转换为: {dt_object_4}, 类型: {type(dt_object_4)}")
常用的格式代码包括:
%Y
: 四位数的年份 (e.g., 2023)%m
: 两位数的月份 (01-12)%d
: 两位数的日期 (01-31)%H
: 24小时制的小时 (00-23)%I
: 12小时制的小时 (01-12)%M
: 两位数的分钟 (00-59)%S
: 两位数的秒 (00-59)%f
: 微秒 (000000-999999)%p
: AM/PM (如果使用%I
)%w
: 星期几 (0-6,星期天是0)%a
,%A
: 简写或完整星期几名称%b
,%B
: 简写或完整月份名称%z
: UTC偏移量 (e.g., +0800)%Z
: 时区名称 (e.g., CST)%j
: 一年中的第几天 (001-366)%U
: 一年中的第几周 (星期天作为一周的开始)%W
: 一年中的第几周 (星期一作为一周的开始)%%
: 字面上的 '%' 字符
完整列表可以参考Python官方文档。
如何处理不同格式的日期字符串?
在实际开发中,我们经常会遇到来自不同系统、不同用户输入的日期时间字符串,它们的格式可能五花八门,甚至有些混乱。说实话,这确实是个让人头疼的问题。strptime()
要求格式严格匹配,如果输入字符串的格式不固定,直接用一个format
字符串去解析,那肯定会频繁报错。
面对这种情况,我通常会采取几种策略:
1. 预设多种格式,尝试解析:
这是最常见也最直接的方法。如果你知道可能出现的几种日期时间格式,你可以将它们放在一个列表中,然后尝试用try-except
块逐一解析。只要有一个格式成功解析,就停止尝试。
from datetime import datetime def parse_flexible_datetime(date_string): formats = [ "%Y-%m-%d %H:%M:%S", "%Y/%m/%d %H:%M:%S", "%Y-%m-%d", "%Y/%m/%d", "%m/%d/%Y", # 注意这种格式可能引起歧义,比如 "01/02/2023" 是 M/D/Y 还是 D/M/Y "%d-%m-%Y %H:%M", "%Y-%m-%dT%H:%M:%S.%f", # ISO 8601 with microseconds "%Y-%m-%dT%H:%M:%S", # ISO 8601 without microseconds ] for fmt in formats: try: return datetime.strptime(date_string, fmt) except ValueError: continue raise ValueError(f"无法解析日期字符串 '{date_string}',没有匹配的格式。") # 测试 print(parse_flexible_datetime("2023-10-27 10:00:00")) print(parse_flexible_datetime("2023/10/27")) print(parse_flexible_datetime("10/27/2023")) # 假设是 M/D/Y print(parse_flexible_datetime("27-10-2023 15:00")) print(parse_flexible_datetime("2023-10-27T14:30:00.123456")) # 如果遇到无法解析的字符串 try: parse_flexible_datetime("Invalid Date String") except ValueError as e: print(e)
这种方法的缺点是,如果格式列表很长,性能可能会受影响。而且,对于像"01/02/2023"
这种模糊的格式,你必须预先决定它应该被解析成M/D/Y还是D/M/Y,否则可能会得到意料之外的结果。
2. 使用第三方库 dateutil
:
对于更“随意”的日期字符串,dateutil
库(特别是dateutil.parser.parse
)是一个非常强大的工具。它能够智能地猜测日期字符串的格式并进行解析,省去了手动维护格式列表的麻烦。
from dateutil.parser import parse from datetime import datetime # 确保已安装:pip install python-dateutil print(parse("2023-10-27 10:00:00")) print(parse("October 27, 2023")) print(parse("27 Oct 2023")) print(parse("2023/10/27 10am")) print(parse("tomorrow")) # 甚至能解析相对日期 print(parse("2023-10-27T14:30:00Z")) # 包含时区的ISO格式 # 它的一个缺点是,对于模糊的格式,它有自己的默认解析规则,可能不总是你想要的 # 比如,"01/02/2023" 默认可能解析成 YYYY-MM-DD 或 YYYY-DD-MM,这取决于区域设置和内部逻辑 # 可以通过 dayfirst=True 或 yearfirst=True 参数来调整 print(parse("01/02/2023", dayfirst=True)) # 假设是 DD/MM/YYYY print(parse("01/02/2023", yearfirst=True)) # 假设是 YY/MM/DD
dateutil
的优点是方便,能处理很多复杂的场景;缺点是它不是Python标准库的一部分,需要额外安装,并且在某些极端情况下,其“智能”解析可能不符合你的预期,尤其是在处理模糊格式时。在对性能要求极高或对解析结果有严格确定性要求的场景,我还是倾向于自己控制strptime
的格式列表。
转换过程中常见的错误有哪些,以及如何调试?
转换字符串到datetime
对象时,最最常见的错误,没有之一,就是ValueError: time data '...' does not match format '%'
. 这个错误信息非常直白,它告诉你输入字符串和你的格式字符串对不上。每次遇到这个错误,我都得深吸一口气,然后开始“找茬”。
常见的错误原因及调试方法:
格式字符串与输入不匹配:
- 原因: 这是最普遍的情况。比如,你的日期字符串是
"2023-10-27"
,但你却用了"%Y/%m/%d"
去解析,分隔符不一致。或者字符串里有时间,但你的格式里没有%H:%M:%S
。 - 调试:
- 逐字对比: 把你的输入字符串和
format
字符串并排打印出来,然后一个字符一个字符地对比。看看分隔符是否一致(-
vs/
vs ` `),数字位数是否一致,是否有额外的字符(比如末尾的空格)。 - 检查大小写: 格式代码是大小写敏感的!
%M
是分钟,%m
是月份。%H
是24小时制,%I
是12小时制。这些小细节很容易被忽略。 - 缺失部分: 字符串里有秒,但格式里没有
%S
?字符串里有毫秒,但格式里没有%f
?这都会导致匹配失败。 - 多余部分: 字符串里只有日期,但格式里却包含了时间部分,如果时间部分在字符串里缺失,也会报错。
- 逐字对比: 把你的输入字符串和
# 错误示例 try: datetime.strptime("2023-10-27", "%Y/%m/%d") # 分隔符不匹配 except ValueError as e: print(f"错误示例1: {e}") try: datetime.strptime("2023-10-27 10:00", "%Y-%m-%d") # 缺少时间部分 except ValueError as e: print(f"错误示例2: {e}") try: datetime.strptime("2023-10-27 10:00:00", "%Y-%M-%d %H:%M:%S") # %M 应该是 %m except ValueError as e: print(f"错误示例3: {e}")
- 原因: 这是最普遍的情况。比如,你的日期字符串是
数据本身不合法:
- 原因: 比如日期字符串是
"2023-13-01"
(月份13),或者"2023-02-30"
(2月没有30号)。strptime()
在解析时会进行基本的合法性检查。 - 调试: 确认输入数据是否在逻辑上是有效的日期时间。
- 原因: 比如日期字符串是
时区信息处理不当:
- 原因: 字符串里有
Z
(Zulu/UTC)或+HHMM
这样的时区偏移,但格式字符串没有正确处理,或者处理方式不正确。 - 调试: 如果有
Z
,strptime
的%z
无法直接解析Z
,通常需要手动替换Z
为+0000
或使用datetime.fromisoformat()
。如果有时区偏移,确保%z
在正确的位置。
- 原因: 字符串里有
Locale(本地化)问题:
- 原因: 当你使用
%a
、%A
(星期几名称)或%b
、%B
(月份名称)时,这些名称是依赖于当前系统locale的。如果你的字符串是英文月份名,但系统locale是中文,或者反过来,就会解析失败。 - 调试: 确保你的程序运行环境的locale设置与日期字符串的语言环境一致,或者避免使用这些依赖locale的格式代码。
- 原因: 当你使用
调试小技巧:
- 逐步构建格式字符串: 如果不确定,可以从日期部分开始,逐步添加时间、秒、毫秒等,每次添加后都测试一下。
- 使用
strftime()
反向验证: 如果你有一个datetime
对象,你可以用dt_object.strftime(your_format)
来生成一个字符串。如果这个生成的字符串和你原始的输入字符串相似,那么你的your_format
很可能就是正确的。这是一个很好的验证方法。
如何处理带有时区信息的日期字符串?
处理带有时区信息的日期字符串是另一个经常让人感到困惑的地方。datetime.strptime()
默认创建的是“naive”(天真)的datetime
对象,这意味着它们没有附带任何时区信息。在很多业务场景中,尤其涉及到跨区域数据时,时区信息至关重要。
1. 使用 %z
解析固定偏移时区:
如果你的日期字符串包含类似+0800
、-0500
这样的UTC偏移量,strptime()
的%z
格式代码可以解析它们,并创建一个“aware”(感知)的datetime
对象。
from datetime import datetime date_str_with_offset = "2023-10-27 14:30:00+0800" dt_aware = datetime.strptime(date_str_with_offset, "%Y-%m-%d %H:%M:%S%z") print(f"带偏移量的字符串 '{date_str_with_offset}' 转换为: {dt_aware}, 时区信息: {dt_aware.tzinfo}") date_str_utc_offset = "2023-10-27 06:30:00Z" # Z 通常表示 UTC,等同于 +0000 # strptime 无法直接解析 'Z',需要手动替换 dt_aware_utc = datetime.strptime(date_str_utc_offset.replace('Z', '+0000'), "%Y-%m-%d %H:%M:%S%z") print(f"UTC字符串 '{date_str_utc_offset}' 转换为: {dt_aware_utc}, 时区信息: {dt_aware_utc.tzinfo}")
需要注意的是,%z
只能解析数字形式的偏移量,对于像"PST"
、"EST"
这样的时区缩写,它无法直接识别。而且,Z
(Zulu time,即UTC)也需要特殊处理。
2. 使用 datetime.fromisoformat()
解析 ISO 8601 字符串:
如果你的日期字符串遵循ISO 8601标准(例如"YYYY-MM-DDTHH:MM:SS.ffffff[+HH:MM]"
),Python 3.7+ 提供的datetime.fromisoformat()
方法是最佳选择。它能直接解析包含时区信息的ISO 8601字符串,并返回一个aware的datetime
对象。
from datetime import datetime iso_str_utc = "2023-10-27T06:30:00Z" dt_iso_utc = datetime.fromisoformat(iso_str_utc.replace('Z', '+00:00')) # fromisoformat 支持 +HH:MM 或 +HHMM print(f"ISO UTC 字符串 '{iso_str_utc}' 转换为: {dt_iso_utc}, 时区信息: {dt_iso_utc.tzinfo}") iso_str_offset = "2023-10-27T14:30:00+08:00" dt_iso_offset = datetime.fromisoformat(iso_str_offset) print(f"ISO 带偏移字符串 '{iso_str_offset}' 转换为: {dt_iso_offset}, 时区信息: {dt_iso_offset.tzinfo}")
fromisoformat()
简洁高效,强烈推荐在处理ISO 8601格式时使用。
3. 结合 pytz
或 zoneinfo
(Python 3.9+) 处理命名时区:
如果你的字符串只包含日期时间,但你知道它属于哪个命名时区(如"Asia/Shanghai"
,"America/New_York"
),你需要先用strptime()
解析成naive对象,然后使用第三方库pytz
(或Python 3.9+的内置zoneinfo
)将其“本地化”(localize)。
from datetime import datetime import pytz # pip install pytz # 假设输入字符串是北京时间(东八区)的naive时间 naive_date_str = "2023-10-27 14:30:00" naive_dt = datetime.strptime(naive_date_str, "%Y-%m-%d %H:%M:%S") # 获取北京时区对象 beijing_tz = pytz.timezone('Asia/Shanghai') # 将naive datetime对象本地化为北京时区 aware_dt_beijing = beijing_tz.localize(naive_dt) print(f"本地化后的北京时间: {aware_dt_beijing}, 时区信息: {aware_dt_beijing.tzinfo}") # 转换为UTC时间(通常推荐内部存储和处理使用UTC) utc_dt = aware_dt_beijing.astimezone(pytz.utc) print(f"转换为UTC时间: {utc_dt}, 时区信息: {utc_dt.tzinfo}") # 转换到另一个时区,比如纽约时间 new_york_tz = pytz.timezone('America/New_York') new_york_dt = aware_dt_beijing.astimezone(new_york_tz) print(f"转换为纽约时间: {new_york_dt}, 时区信息: {new_york_dt.tzinfo}")
pytz
或zoneinfo
库对于处理复杂的命名时区转换(包括夏令时等)是必不可少的。核心思路是:先解析成naive对象,然后通过时区对象将其“武装”成aware对象,之后就可以在不同时区之间安全地转换了。
在我看来,处理时区最稳妥的实践是:所有输入数据在解析后,都立即转换为UTC时间进行内部处理和存储。只有
理论要掌握,实操不能落!以上关于《Python字符串转datetime方法详解》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

- 上一篇
- Greenshot添加水印教程自定义图文指南

- 下一篇
- Win11安卓子系统开启方法WSA安装教程
-
- 文章 · python教程 | 28分钟前 |
- Docker容器化Python应用教程
- 478浏览 收藏
-
- 文章 · python教程 | 50分钟前 |
- Python正则表达式使用教程
- 382浏览 收藏
-
- 文章 · python教程 | 51分钟前 | Python 包安装
- Python包安装全攻略详解
- 271浏览 收藏
-
- 文章 · python教程 | 55分钟前 |
- Tkinter控件动态更新,消除残影技巧解析
- 264浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python如何判断键是否存在
- 197浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Fabric自动化部署教程:高效使用指南
- 389浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Pythonlogging模块使用全攻略
- 141浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- 计算办公时间的Python技巧
- 145浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Tkinter找钻石避坑指南详解
- 495浏览 收藏
-
- 文章 · python教程 | 3小时前 | Python Python编程
- Pythonimportlib依赖分析技巧
- 204浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- Python发送HTTP请求:urllib实用技巧详解
- 143浏览 收藏
-
- 文章 · python教程 | 3小时前 | Template MVC模式 model View DjangoMTV模式
- DjangoMTV模式解析与实战应用
- 178浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 514次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 748次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 763次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 781次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 846次使用
-
- 迅捷AIPPT
- 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
- 735次使用
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览