python time的使用

Python 的 time 模块是处理时间相关任务的核心内置库,它提供了从获取时间戳、格式化时间到程序延时和性能测量等一系列功能。以下是该模块主要功能与使用方法的详细解析。

一、 模块导入与基础时间获取

使用 time 模块的第一步是导入它。

复制代码
import time

导入后,最基础的功能是获取当前时间,通常以时间戳(自1970年1月1日UTC以来的秒数,浮点数形式)表示。

复制代码
current_timestamp = time.time()
print(f"当前时间戳: {current_timestamp}")

时间戳可读性差,time.ctime() 能将其转换为本地时间的字符串。

复制代码
readable_time = time.ctime()
print(f"可读时间: {readable_time}")

二、 时间格式的转换与解析

time 模块在时间戳、结构化时间对象和字符串之间提供了灵活的转换工具。

  1. 获取结构化时间

    • time.localtime([secs]): 将时间戳转换为本地时间的 struct_time 对象。若不提供参数,则使用当前时间。
    • time.gmtime([secs]): 将时间戳转换为UTC时间的 struct_time 对象。
  2. 时间格式化与解析

    • 格式化 (time.strftime()) :将 struct_time 对象按指定格式转换为字符串。这是生成可读日期时间字符串的常用方法。

      local_time = time.localtime()
      formatted_time = time.strftime("%Y-%m-%d %H:%M:%S", local_time)
      print(f"格式化时间: {formatted_time}") # 输出如:2025-12-11 10:30:00

    • 解析 (time.strptime()) :将格式匹配的字符串解析为 struct_time 对象。

      time_str = "2025-12-11 10:30:00"
      parsed_time = time.strptime(time_str, "%Y-%m-%d %H:%M:%S")
      print(parsed_time)

  3. 时间对象与时间戳互转

    • time.mktime(t): 将本地时间的 struct_time 对象转换回时间戳。
    • time.asctime([t]): 将 struct_time 对象转换为一个可读的字符串,格式类似于 ctime()

三、 程序控制与性能测量

  1. 延时执行 time.sleep(seconds) 函数使当前线程暂停执行指定的秒数(可为浮点数),常用于控制节奏或模拟等待。这在网络爬虫中用于避免请求过快,或在自动化测试中模拟用户操作间隔。

    复制代码
    print("开始")
    time.sleep(2.5) # 暂停2.5秒
    print("结束")
  2. 测量时间间隔与性能

    • 简单测量 :使用 time.time() 记录起止时间戳并计算差值,适用于测量代码段执行时间。
    • 高精度测量
      • time.perf_counter(): 返回一个具有最高可用精度的性能计数器的值,用于测量极短时间间隔。
      • time.process_time(): 返回当前进程的系统和用户CPU时间总和,用于测量代码实际消耗的CPU时间。
    • 单调时钟time.monotonic() 返回一个单调递增的时钟值,不受系统时间调整影响,适用于测量时间间隔。
    • 纳秒级精度time.time_ns() 返回纳秒级精度的时间戳。

四、 实际应用场景

  1. 创建定时任务 :结合循环与 time.sleep(),可以实现简单的定时执行功能,例如定期备份文件或检查状态。

    复制代码
    def scheduled_task():
        print(f"任务执行于 {time.strftime('%H:%M:%S')}")
    while True:
        scheduled_task()
        time.sleep(5) # 每5秒执行一次
  2. 实现倒计时 :利用 time.sleep() 和循环可以创建命令行倒计时。

  3. 计算函数执行时间 :使用装饰器模式可以优雅地为函数添加计时功能,便于性能分析和调试。

    复制代码
    import time
    def timer_decorator(func):
        def wrapper(*args, **kwargs):
            start = time.perf_counter()
            result = func(*args, **kwargs)
            end = time.perf_counter()
            print(f"{func.__name__} 执行耗时: {end - start:.6f} 秒")
            return result
        return wrapper
    @timer_decorator
    def my_function():
        time.sleep(1)
    my_function()
  4. 多线程中的时间控制 :在多线程编程中,time.sleep() 常用于控制不同线程的执行节奏或间隔。

五、 注意事项与与其他模块的协作

  • 时区处理localtime()gmtime() 分别提供本地和UTC时间,在处理跨时区应用时需注意区分。
  • 格式匹配 :使用 strptime() 解析字符串时,格式字符串必须与时间字符串严格匹配,否则会引发错误。
  • 模块协作 :对于更复杂的日期时间操作(如日期加减、比较),datetime 模块功能更强大。对于需要事件调度的场景,可以参考 sched 模块。calendar 模块则专注于日历相关的操作。

总结

Python 的 time 模块是一个功能全面且直接的工具集,涵盖了从基础时间获取、格式化、程序延时到高精度性能测量的核心需求。掌握其常用函数如 time()sleep()strftime()/strptime()localtime()/gmtime() 以及 perf_counter(),能够高效地解决开发中大多数与时间相关的编程任务。对于更复杂的日期时间处理,可结合 datetime 等模块共同使用。

相关推荐
BoBoZz1918 分钟前
MotionBlur 演示简单运动模糊
python·vtk·图形渲染·图形处理
十八度的天空38 分钟前
第01节 Python的基础语法
开发语言·python
BoBoZz1938 分钟前
GradientBackground 比较不同类型的背景渐变着色模式与坐标转换
python·vtk·图形渲染·图形处理
540_5401 小时前
ADVANCE Day32
人工智能·python·机器学习
STLearner1 小时前
AAAI 2026 | 图基础模型(GFM)&文本属性图(TAG)高分论文
人工智能·python·深度学习·神经网络·机器学习·数据挖掘·图论
小北方城市网1 小时前
Python + 前后端全栈进阶课程(共 10 节|完整版递进式|从技术深化→项目落地→就业进阶,无缝衔接基础课)
大数据·开发语言·网络·python·数据库架构
nvd111 小时前
故障排查:Pytest Asyncio Event Loop Closed 错误
python
deephub2 小时前
Lux 上手指南:让 AI 直接操作你的电脑
人工智能·python·大语言模型·agent
Channing Lewis2 小时前
Python读取excel转成html,并且复制excel中单元格的颜色(字体或填充)
python·html·excel
小钟不想敲代码2 小时前
Python(一)
开发语言·python