Python处理日期时间最核心的是datetime模块,含date、time、datetime、timedelta四大类;支持当前时间获取、字符串解析与格式化、加减比较运算及时区处理(推荐zoneinfo)。

Python 中处理日期和时间最常用、最核心的模块就是 datetime。它不依赖外部库,标准库自带,功能完整且设计清晰。掌握它,就能应对绝大多数日常开发中的时间需求——比如记录日志时间、计算两个时间点的间隔、格式化输出、时区转换(配合 zoneinfo)、生成时间序列等。
datetime 模块的四大核心类
模块里最关键的四个类,各司其职,别混用:
-
date:只管年月日,比如
date(2024, 5, 20),不能带时分秒; -
time:只管时分秒和微秒,比如
time(14, 30, 45, 123456),不关心是哪天; -
datetime:date + time 的组合,最常用,比如
datetime(2024, 5, 20, 14, 30, 45); - timedelta:表示“一段时间差”,比如“3天”“2小时30分钟”,用于加减运算,不是某个具体时刻。
获取当前时间 & 创建指定时间
创建对象有明确方法,不建议直接调用构造函数传字符串(容易出错):
- 获取现在:
datetime.now()返回本地时区的 datetime 对象;datetime.utcnow()返回 UTC 时间(已弃用,推荐用datetime.now(timezone.utc)); - 从字符串解析:
datetime.strptime("2024-05-20 14:30", "%Y-%m-%d %H:%M"),注意格式符必须严格匹配; - 转成字符串:
dt.strftime("%Y年%m月%d日 %H:%M"),这是最常用的格式化方式; - 构造固定时间:
datetime(2024, 5, 20, 9, 0),参数顺序固定为年、月、日、时、分、秒、微秒。
时间运算:加减与比较
datetime 对象支持直接加减 timedelta,也支持彼此比较大小(早于/晚于):
立即学习“Python免费学习笔记(深入)”;
- 三天后:
dt + timedelta(days=3); - 两小时十五分钟前:
dt - timedelta(hours=2, minutes=15); - 两个 datetime 相减得到 timedelta:
later_dt - earlier_dt,结果可访问.days、.seconds、.total_seconds(); - 判断是否过期:
if dt 。
时区处理(Python 3.9+ 推荐方式)
原生 datetime 是“无时区”的(naive),带时区的叫 aware。处理时区推荐用标准库 zoneinfo(3.9+ 内置):
- 加载时区:
from zoneinfo import ZoneInfo; tz = ZoneInfo("Asia/Shanghai"); -
本地化时间:
dt.replace(tzinfo=tz)(仅适用于已知本地时区); - 更安全做法:
datetime(2024, 5, 20, 14, 0, tzinfo=tz)或datetime.now(tz); - 转换时区:
dt.astimezone(ZoneInfo("UTC")),自动处理夏令时等细节。
不复杂但容易忽略:做时间运算或比较前,确保所有 datetime 对象都是同一种类型——要么全 naive,要么全 aware。混用会报 TypeError。










