0

0

python中怎么将字符串转换为datetime对象?

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-09-18 11:01:01

|

994人浏览过

|

来源于php中文网

原创

使用datetime.strptime()可将字符串转为datetime对象,需确保格式代码与字符串严格匹配,如%Y-%m-%d对应"2023-10-27";对不同时区或模糊格式,可借助dateutil.parser.parse或fromisoformat()处理,并建议内部统一用UTC时间。

python中怎么将字符串转换为datetime对象?

在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)}")

常用的格式代码包括:

立即学习Python免费学习笔记(深入)”;

  • %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 '%'
. 这个错误信息非常直白,它告诉你输入字符串和你的格式字符串对不上。每次遇到这个错误,我都得深吸一口气,然后开始“找茬”。

常见的错误原因及调试方法:

JSON.NET 简单的使用 中文WORD版
JSON.NET 简单的使用 中文WORD版

本文档主要讲述的是JSON.NET 简单的使用;JSON.NET使用来将.NET中的对象转换为JSON字符串(序列化),或者将JSON字符串转换为.NET中已有类型的对象(反序列化?)。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载
  1. 格式字符串与输入不匹配:

    • 原因: 这是最普遍的情况。比如,你的日期字符串是
      "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}")
  2. 数据本身不合法:

    • 原因: 比如日期字符串是
      "2023-13-01"
      (月份13),或者
      "2023-02-30"
      (2月没有30号)。
      strptime()
      在解析时会进行基本的合法性检查。
    • 调试: 确认输入数据是否在逻辑上是有效的日期时间。
  3. 时区信息处理不当:

    • 原因: 字符串里有
      Z
      (Zulu/UTC)或
      +HHMM
      这样的时区偏移,但格式字符串没有正确处理,或者处理方式不正确。
    • 调试: 如果有
      Z
      strptime
      %z
      无法直接解析
      Z
      ,通常需要手动替换
      Z
      +0000
      或使用
      datetime.fromisoformat()
      。如果有时区偏移,确保
      %z
      在正确的位置。
  4. 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速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

718

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

627

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

744

2023.07.25

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

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

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1236

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

700

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

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

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