当前位置: 首页 > news >正文

python中的与时间相关的模块

python中的与时间相关的模块

  • 1. time 模块
  • 2. datetime 模块
  • 3. calendar 模块
  • 4. timeit 模块
  • 5. pytz 模块
  • 6. dateutil 模块
  • 参考资料

1. time 模块

time 模块提供了时间相关的函数,主要用于测量时间间隔、获取当前时间、格式化时间等

主要功能

  • 获取当前时间:time.time() 返回自纪元以来的秒数(浮点数)
  • 时间戳转换为结构化时间:time.localtime() 或 time.gmtime() 将时间戳转换为本地时间或 UTC 时间的结构化时间
  • 结构化时间转换为时间戳:time.mktime() 将结构化时间转换为时间戳
  • 格式化时间:time.strftime() 将结构化时间格式化为字符串
  • 时间延迟:time.sleep() 暂停执行指定的秒数
import time# 获取当前时间戳
timestamp = time.time()
print("Current timestamp:", timestamp)# 将时间戳转换为结构化时间
local_time = time.localtime(timestamp)
print("Local time:", local_time)# 将结构化时间转换为字符串
formatted_time = time.strftime("%Y-%m-%d %H:%M:%S", local_time)
print("Formatted time:", formatted_time)# 暂停 2 秒
print("Sleeping for 2 seconds...")
time.sleep(2)
print("Awake!")

2. datetime 模块

datetime 模块提供了处理日期和时间的类,比 time 模块更加灵活和强大

主要功能

  • 日期和时间类:datetime.date、datetime.time、datetime.datetime
  • 获取当前日期和时间:datetime.datetime.now() 或 datetime.datetime.utcnow()
  • 日期时间运算:datetime.timedelta 用于表示时间差
  • 时区处理:datetime.timezone 用于定义时区
  • 格式化和解析:datetime.datetime.strftime() 和 datetime.datetime.strptime()
from datetime import datetime, timedelta# 获取当前日期时间
now = datetime.now()
print("Current datetime:", now)# 格式化日期时间
formatted_date = now.strftime("%Y-%m-%d %H:%M:%S")
print("Formatted datetime:", formatted_date)# 解析日期时间字符串
parsed_date = datetime.strptime("2024-12-25 10:30:00", "%Y-%m-%d %H:%M:%S")
print("Parsed datetime:", parsed_date)# 日期时间运算
future_date = now + timedelta(days=7)
print("7 days from now:", future_date)# 时区处理
from datetime import timezoneutc_now = datetime.now(timezone.utc)
print("UTC now:", utc_now)

3. calendar 模块

calendar 模块提供了处理日期和日历的函数,可以生成日历、检查闰年、计算月份天数等

主要功能

  • 生成日历:calendar.month() 生成指定月份的日历
  • 检查闰年:calendar.isleap() 判断某一年是否为闰年
  • 计算月份天数:calendar.monthrange() 返回指定月份的第一天是星期几以及该月的天数
import calendar# 生成 2024 年 12 月的日历
cal = calendar.month(2024, 12)
print("Calendar for December 2024:\n", cal)# 检查 2024 年是否为闰年
is_leap = calendar.isleap(2024)
print("Is 2024 a leap year?", is_leap)# 计算 2024 年 12 月的天数
month_range = calendar.monthrange(2024, 12)
print("December 2024 starts on a", calendar.day_name[month_range[0]], "and has", month_range[1], "days.")

4. timeit 模块

timeit 模块用于测量小段代码的执行时间,通常用于性能测试

主要功能

  • 测量代码执行时间:timeit.timeit() 测量代码的执行时间
  • 多次执行:可以指定代码执行的次数,以获得更精确的测量结果
import timeit# 测量列表推导式和普通循环的执行时间
list_comp_time = timeit.timeit('[i for i in range(1000)]', number=10000)
loop_time = timeit.timeit('l = []; for i in range(1000): l.append(i)', number=10000)print("List comprehension time:", list_comp_time)
print("Loop time:", loop_time)

5. pytz 模块

pytz 模块用于处理时区和夏令时,提供了全球时区的定义

主要功能

  • 时区转换:将时间转换为特定时区的时间
  • 夏令时处理:自动处理夏令时的转换
import pytz
from datetime import datetime# 获取当前时间并转换为纽约时间
utc_now = datetime.now(pytz.utc)
ny_tz = pytz.timezone('America/New_York')
ny_now = utc_now.astimezone(ny_tz)print("UTC now:", utc_now)
print("New York now:", ny_now)# 获取所有可用时区
all_timezones = pytz.all_timezones
print("Available timezones:", all_timezones)

6. dateutil 模块

dateutil 模块是 datetime 模块的扩展,提供了更强大的日期解析和操作功能

主要功能

  • 日期解析:dateutil.parser.parse() 可以解析各种格式的日期字符串
  • 相对日期:dateutil.relativedelta 用于表示相对日期差
from dateutil import parser, relativedelta# 解析日期字符串
parsed_date = parser.parse("2024-12-25 10:30:00")
print("Parsed date:", parsed_date)# 相对日期运算
from datetime import datetimenow = datetime.now()
future_date = now + relativedelta.relativedelta(months=1, days=5)
print("1 month and 5 days from now:", future_date)

应用场景

  • 系统日志:记录系统事件的时间戳
  • 定时任务:使用 time.sleep() 或 threading.Timer 实现定时任务
  • 时间格式化:将时间格式化为用户友好的字符串
  • 性能测试:使用 timeit 模块测量代码的执行时间
  • 时区转换:使用 pytz 或 datetime 处理时区转换和夏令时
  • 日期解析:使用 dateutil 解析各种格式的日期字符串

参考资料

  • Python官方文档 - time模块
  • Python官方文档 - datetime模块
  • Python官方文档 - calendar模块
  • Python官方文档 - timeit模块
  • pytz文档
  • dateutil文档

相关文章:

python中的与时间相关的模块

python中的与时间相关的模块 1. time 模块2. datetime 模块3. calendar 模块4. timeit 模块5. pytz 模块6. dateutil 模块参考资料 1. time 模块 time 模块提供了时间相关的函数,主要用于测量时间间隔、获取当前时间、格式化时间等 主要功能 获取当前时间&#xff…...

【Python运维】构建基于Python的自动化运维平台:用Flask和Celery

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 在现代IT运维中,自动化运维平台扮演着至关重要的角色,它能够显著提高运维效率,减少人为错误,并且增强系统的可维护性。本文将引导读者如…...

Qt 12.28 day3

作业: 1】 思维导图 2】 在登录界面的登录取消按钮进行以下设置: 使用手动连接,将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中,在自定义的槽函数中调用关闭函数 将登录按钮使用qt5版本的连接到自定义的槽函数中&a…...

Java爬虫获取速卖通(AliExpress)商品详情

1. 环境准备 在开始编写爬虫之前,需要准备以下环境和工具: Java开发环境:确保你的计算机上安装了Java开发工具包(JDK)。IDE:选择一个Java集成开发环境,如IntelliJ IDEA、Eclipse等。第三方库&…...

Learning Multi-Scale Photo Exposure Correction

Abstract 用错误的曝光捕捉照片仍然是相机成像的主要错误来源。曝光问题可分为以下两类:(i)曝光过度,即相机曝光时间过长,导致图像区域明亮和褪色;(ii)曝光不足,即曝光时间过短,导致图像区域变暗。曝光不足和曝光过度都会大大降低…...

【Rust自学】7.4. use关键字 Pt.1:use的使用与as关键字

喜欢的话别忘了点赞、收藏加关注哦,对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 7.4.1. use的作用 use的作用是将路径导入到当前作用域内。而引入的内容仍然是遵守私有性原则,也就是只有公共的部分引入进来才…...

C++ 设计模式:门面模式(Facade Pattern)

链接:C 设计模式 链接:C 设计模式 - 代理模式 链接:C 设计模式 - 中介者 链接:C 设计模式 - 适配器 门面模式(Facade Pattern)是一种结构型设计模式,它为子系统中的一组接口提供一个一致&#…...

从0到100:基于Java的大学选修课选课小程序开发笔记(上)

背景 为学生提供便捷的课程选择方式,并帮助学校进行课程管理和资源调配;主要功能包括:课程展示,自主选课,取消选课,后台录入课程,统计每门课程报名情况,导出数据,用户管…...

【算法题解】B. President‘s Office - Python实现

题目描述 Berland的总统办公室内设有多个办公桌,其中总统和其属下各自拥有独特颜色的办公桌。总统希望统计哪些属下的办公桌紧邻他的办公桌,但不记得确切的数量。 输入描述: 第一行包含三个值 n, m, c,分别是办公室的长度、宽度…...

【Spring Boot 】详解

Spring Boot 详解 一、Spring Boot 概述 (一)产生背景 随着 Java 应用的日益复杂,传统 Spring 框架在项目搭建与配置方面愈发繁琐,大量的 XML 配置、依赖管理等工作耗费开发者诸多精力。为解决这些痛点,Spring Boot …...

Redisson 框架详解

目录 一.为什么要使用分布式锁? 二.Redisson 的基本使用: 1.添加 Redisson 依赖: 2.在 application.yml 配置 Redis: 3. 创建 Redisson 客户端: (1)单节点模式: (…...

正确导入MapStruct并避免与Lombok编译冲突的深入分析

正确导入MapStruct并避免与Lombok编译冲突的深入分析 一、MapStruct与Lombok概述 1.1 MapStruct简介 MapStruct是一个代码生成器,它基于约定优于配置的原则,通过注解处理器在编译时自动生成源代码,实现对象之间的属性映射。MapStruct的优势在于减少样板代码,提高开发效率…...

K8S 黑魔法之如何从 Pod 拿到节点的命令行

搞 K8S 运维的时候,偶尔会遇到一个难题,定位到问题出在某个节点上,而由于权限审批,错误配置等等各种原因,没有办法拿到节点的 SSH 权限,无法进入节点命令行进一步排障。 这个时候,就可以用这个…...

【bluedroid】A2dp Source播放流程源码分析(4)

接上集分析:【bluedroid】A2dp Source播放流程源码分析(3)-CSDN博客 蓝牙和AUDIO之间的接口 蓝牙和audio之间的通信是通过socket,管理socket中的文件是UIPC,UIPC管理两条socket。 A2DP_CTRL_PATH /data/misc/bluedroid/.a2dp_ctrl A2DP_DATA_PATH /data/misc/bluedroid…...

计算机网络 (9)数据链路层

前言 计算机网络中的数据链路层(Data Link Layer)是OSI(开放系统互连)参考模型中的第二层,位于物理层和网络层之间。它在物理层提供的服务基础上,负责在相邻节点之间建立、维护和终止链路,确保数…...

kubernetes学习-集群搭建部署(一)

一、开三台虚拟机进行试验(centos7) 1、初始操作 # 关闭防火墙 systemctl stop firewalld systemctl disable firewalld# 关闭selinux sudo sed -i s/enforcing/disabled/ /etc/selinux/config # 永久 setenforce 0 # 临时# 关闭swap sudo swapoff -a # 临时 s…...

docker commit生成的镜像瘦身

1、清除宿主系统的docker资源 docker system prune -a --volumes 2、清理容器内系统的临时文件和缓存 # 删除包管理器缓存 apt-get clean rm -rf /var/lib/apt/lists/* # 删除日志文件 rm -rf /var/log/* # 删除临时文件 rm -rf /tmp/* 3、安装docker squash工具&#xff0…...

基于Spring Boot的宠物领养系统的设计与实现(代码+数据库+LW)

摘 要 如今社会上各行各业,都在用属于自己专用的软件来进行工作,互联网发展到这个时候,人们已经发现离不开了互联网。互联网的发展,离不开一些新的技术,而新技术的产生往往是为了解决现有问题而产生的。针对于宠物领…...

7.若依参数设置、通知公告、日志管理

参数设置 对系统中的参数进行动态维护。 关闭验证码校验功能 打开页面注册功能 需要修改前端页面代码 通知公告 促进组织内部信息传递 若依只提供了一个半成品,只实现了管理员可以添加通知公告。 日志管理 追踪用户行为和系统运行状况。 登录日志 和操作日志…...

基于FISCO BCOS的电子签署系统

概述 本项目致力于构建一个安全、高效且功能完备的电子签署系统,通过整合区块链技术与传统数据库管理,为用户提供了可靠的电子签署解决方案,有效应对传统电子签署系统的数据安全隐患,满足企业和个人在数字化办公环境下对电子文档…...

django filter 统计数量 按属性去重

在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...

如何在看板中有效管理突发紧急任务

在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 (部分有免费额度&#x…...

零基础设计模式——行为型模式 - 责任链模式

第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...

Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理

引言 Bitmap(位图)是Android应用内存占用的“头号杀手”。一张1080P(1920x1080)的图片以ARGB_8888格式加载时,内存占用高达8MB(192010804字节)。据统计,超过60%的应用OOM崩溃与Bitm…...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念,其实 Fiori当中还有 V4,咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务),代理中间件(ui5-middleware-simpleproxy)-CSDN博客…...

2025季度云服务器排行榜

在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...

管理学院权限管理系统开发总结

文章目录 🎓 管理学院权限管理系统开发总结 - 现代化Web应用实践之路📝 项目概述🏗️ 技术架构设计后端技术栈前端技术栈 💡 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 🗄️ 数据库设…...

无人机侦测与反制技术的进展与应用

国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机(无人驾驶飞行器,UAV)技术的快速发展,其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统,无人机的“黑飞”&…...

Linux 中如何提取压缩文件 ?

Linux 是一种流行的开源操作系统,它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间,使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的,要在 …...