当前位置:首页 > 随笔 > 正文内容

Python时间处理核心模块详解

访客 随笔 2026年5月23日 3

Python时间处理核心模块详解

在Python开发中,精确的时间操作是许多应用场景的基础,如日志记录、定时任务、性能监控等。标准库中的time模块提供了对时间戳、本地时间、格式化输出以及程序延时等功能的底层支持。本文将系统讲解该模块的核心函数及其实际用法。

标准库简介与导入方式

Python标准库无需额外安装,随解释器一同发布。可通过以下代码查看其安装路径:

import sys
print(sys.exec_prefix)

标准库位于Python安装目录下的Lib文件夹中。使用time模块前需先导入,常见方式包括:

  • import time:导入整个模块
  • from time import sleep:仅导入指定函数
  • from time import *:导入所有公开成员(不推荐用于生产环境)
  • import time as tm:为模块设置别名以简化调用

当执行import module_name时,Python按如下顺序搜索模块:

  1. 当前脚本所在目录
  2. 标准库路径(Lib/
  3. 第三方包路径(site-packages/

若未找到对应模块,则抛出ModuleNotFoundError异常。

获取时间戳

时间戳(Timestamp)表示自1970年1月1日00:00:00 UTC以来经过的秒数,常用于记录事件发生的时间点或计算程序运行耗时。

import time

timestamp = time.time()
print(f"当前时间戳:{timestamp}")
# 示例输出:1752137285.4044664

利用时间戳可测量代码段执行时间:

start_time = time.time()

count = 0
while count < 100_000_000:
    count += 1

end_time = time.time()
duration = end_time - start_time
print(f"循环耗时:{duration:.4f} 秒")

I/O操作对性能的影响

频繁的I/O操作会显著影响程序性能。例如,在循环中加入print()语句会导致大量系统调用,从而大幅增加执行时间:

# 包含print的循环
start = time.time()
for i in range(1_000_000):
    print(i)  # 每次输出都会触发I/O
end = time.time()
print(f"I/O密集型耗时:{end - start:.2f} 秒")

相比之下,将数据写入文件比屏幕输出更高效:

with open('output.txt', 'w') as f:
    start = time.time()
    for i in range(1_000_000):
        f.write(f"{i}\n")
    end = time.time()
print(f"文件写入耗时:{end - start:.2f} 秒")

获取结构化时间

localtime() —— 获取本地时间

time.localtime([secs])返回一个struct_time对象,包含年、月、日、时、分、秒等字段。若未传参,则返回当前本地时间。

local_t = time.localtime()
print(local_t)
# 输出示例:
# time.struct_time(tm_year=2025, tm_mon=7, tm_mday=10, tm_hour=19, tm_min=35, tm_sec=53,
#                  tm_wday=3, tm_yday=191, tm_isdst=0)

# 转换特定时间戳
converted = time.localtime(1622874693.666)
print(converted.tm_year, converted.tm_mon, converted.tm_mday)  # 2021 6 5

gmtime() —— 获取UTC时间

time.gmtime([secs])返回世界协调时间(UTC),适用于跨时区应用的时间统一处理。

utc_time = time.gmtime()
print(utc_time)
# 输出示例:
# time.struct_time(tm_year=2025, tm_mon=7, tm_mday=10, tm_hour=11, tm_min=40, tm_sec=51,
#                  tm_wday=3, tm_yday=191, tm_isdst=0)

ctime() —— 获取可读字符串时间

time.ctime([secs])返回C风格的时间字符串,便于日志打印。

readable_time = time.ctime()
print(readable_time)
# 输出示例:Thu Jul 10 19:44:18 2025

时间格式转换

mktime() —— 结构化时间转时间戳

time.mktime(t)struct_time对象转换回浮点型时间戳,常用于时间计算。

now_struct = time.localtime()
now_timestamp = time.mktime(now_struct)
print(now_timestamp)  # 如:1752148652.0

strftime() —— 格式化时间输出

time.strftime(format, t)根据指定格式生成时间字符串。常用格式符如下:

格式符含义取值范围/示例
%Y四位年份1900–9999
%m月份01–12
%d日期01–31
%H小时(24制)00–23
%M分钟00–59
%S00–59
%A完整星期名Monday–Sunday
%B完整月份名January–December
formatted = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
print(formatted)  # 2025-07-10 20:05:28

strptime() —— 字符串解析为结构化时间

time.strptime(string, format)将格式化字符串解析为struct_time对象,是strftime()的逆操作。

date_str = "2021-09-30"
parsed_time = time.strptime(date_str, "%Y-%m-%d")
print(parsed_time)
# 输出:
# time.struct_time(tm_year=2021, tm_mon=9, tm_mday=30, tm_hour=0, tm_min=0, tm_sec=0,
#                  tm_wday=3, tm_yday=273, tm_isdst=-1)

程序休眠控制

time.sleep(seconds)使程序暂停指定秒数,参数可为整数或浮点数,适用于延时执行、限流、轮询等场景。

print("开始等待...")
time.sleep(3.5)  # 暂停3.5秒
print("3.5秒后继续执行")
标签: time

相关文章

可以按小时收费的VPS

很多 VPS 提供商都支持 按小时计费(hourly billing),想短期试用 / 临时搭建节点、测试网络、短期项目等场景非常合适。下面是当前最主流且靠谱的按小时 VPS 选项,分别按不同需求场景整理: 1. Vultr(全球节点,包括日本) 按小时计费 可选机房:东京 / 大阪 / 洛杉矶 / 法兰克福 / 伦敦 … 支持 PayPal(部分情况),但更常用信用卡/PayPal+卡价格参考$...

在 iPhone 上下载国外App

地区/国家限制App Store 会根据 Apple ID 的国家或地区限制应用下载。如果你的 Apple ID 绑定的是中国大陆,就可能无法下载 OpenAI 官方的 ChatGPT 应用,因为它在大陆 App Store 不上架。解决办法:换成美国、加拿大、香港等地区的 Apple ID。或者在现有 Apple ID 上更改地区。注册一个国外 Apple ID(推荐)比如注册 美国区 Appl...

Node.js 中的异步编程:回调与 Promise

Node.js 是一个基于 JavaScript 构建的单线程、非阻塞运行环境,它通过异步编程机制来高效处理多个操作。在执行如文件读取、API 请求或数据库查询等任务时,Node.js 不会等待这些操作完成,而是使用回调函数和 Promise 来避免阻塞主线程。 回调方式实现异步 那么当异步操作完成后,Node.js 如何知道接下来要做什么呢?这就要用到 回调函数(callback)。 回调本质上...

Selenium自动化测试入门指南

Selenium自动化测试入门指南

什么是自动化测试? 自动化测试是指利用软件工具自动执行测试用例,模拟用户操作,如打开网页、点击链接、输入文本等,并验证结果是否符合预期。 其主要优点包括: 大幅减少人工成本 测试速度快 可以在非工作时间运行 支持持续集成和交付 然而,它也存在一些局限性,例如开发成本较高、不适合快速变化的项目、依赖稳定的UI界面等。 自动化测试的应用条件 适合引入自动化测试的情况包括: 手动测试耗时且需要大量...

MariaDB Galera集群故障快速恢复指南

OpenStack控制节点采用三节点MariaDB Galera集群架构。当数据库集群因故障重启时,有时会出现Galera集群无法正常启动的问题。虽然有多种方法可以恢复数据库服务,但如何实现快速启动同时确保数据完整性呢? 通过分析日志发现,MariaDB Galera集群节点宕机时会在日志中输出以下信息: [Note] WSREP: 新集群视图:全局状态: 874d8e7e-5980-11e8-8...

Android 中 EventBus 的通信机制与实现原理深度解析

EventBus 核心设计思想 EventBus 是一个基于观察者模式的事件总线框架,广泛应用于 Android 平台以实现组件解耦。它通过中心化的消息分发机制,使不同层级、不同线程的对象能够以"发布-订阅"方式通信,避免了传统接口回调或广播带来的强依赖问题。 核心角色说明 事件(Event):任意 Java 对象,作为数据载体,如网络状态变更通知、用户登录信息等。 发布者(Publi...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。