当前位置: 首页 > 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的电子签署系统

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

浅谈 React Hooks

React Hooks 是 React 16.8 引入的一组 API,用于在函数组件中使用 state 和其他 React 特性(例如生命周期方法、context 等)。Hooks 通过简洁的函数接口,解决了状态与 UI 的高度解耦,通过函数式编程范式实现更灵活 Rea…...

大数据学习栈记——Neo4j的安装与使用

本文介绍图数据库Neofj的安装与使用,操作系统:Ubuntu24.04,Neofj版本:2025.04.0。 Apt安装 Neofj可以进行官网安装:Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...

边缘计算医疗风险自查APP开发方案

核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...

WordPress插件:AI多语言写作与智能配图、免费AI模型、SEO文章生成

厌倦手动写WordPress文章?AI自动生成,效率提升10倍! 支持多语言、自动配图、定时发布,让内容创作更轻松! AI内容生成 → 不想每天写文章?AI一键生成高质量内容!多语言支持 → 跨境电商必备&am…...

Ascend NPU上适配Step-Audio模型

1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统,支持多语言对话(如 中文,英文,日语),语音情感(如 开心,悲伤)&#x…...

Spring AI 入门:Java 开发者的生成式 AI 实践之路

一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...

浅谈不同二分算法的查找情况

二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况&#xf…...

Web 架构之 CDN 加速原理与落地实践

文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 &#xf…...

中医有效性探讨

文章目录 西医是如何发展到以生物化学为药理基础的现代医学?传统医学奠基期(远古 - 17 世纪)近代医学转型期(17 世纪 - 19 世纪末)​现代医学成熟期(20世纪至今) 中医的源远流长和一脉相承远古至…...

浪潮交换机配置track检测实现高速公路收费网络主备切换NQA

浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...