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

09-扩展知识——02. 初识 datetime 模块

02. 初识 datetime 模块概述datetime是 Python 处理日期和时间的核心模块提供了date、time、datetime、timedelta、tzinfo五个主要类。掌握这个模块是时间处理的基础。维度内容Whatdatetime 模块的五大核心类及其基本用法Why日常日期时间操作的首选模块When需要处理日期、时间、时间差、时区时Whereimport datetime或from datetime import date, time, datetimeWho所有 Python 开发者How根据需求选择合适的类和方法1. datetime 模块五大类概览┌─────────────────────────────────────────────────────────────────┐ │ datetime 模块五大类 │ ├─────────────────────────────────────────────────────────────────┤ │ │ │ date - 处理日期年、月、日 │ │ time - 处理时间时、分、秒、微秒 │ │ datetime - 处理日期 时间date time │ │ timedelta - 处理时间差/持续时间 │ │ tzinfo - 时区信息基类抽象类 │ │ timezone - 时区实现类Python 3.2tzinfo 的子类 │ │ │ └─────────────────────────────────────────────────────────────────┘1.1 五大类对比类最小单位是否包含时区常见用途date日❌生日、节假日、日期范围time微秒✅可选时间点、闹钟datetime微秒✅可选时间戳、日志、订单时间timedelta微秒❌时间差、倒计时tzinfo-✅时区定义基类2. 导入方式# 方式1导入整个模块推荐避免命名冲突importdatetime ddatetime.date(2026,4,19)nowdatetime.datetime.now()# 方式2直接导入需要的类fromdatetimeimportdate,time,datetime,timedelta,timezone ddate(2026,4,19)nowdatetime.now()# 方式3导入所有不推荐fromdatetimeimport*3. date 类日期3.1 创建 date 对象fromdatetimeimportdate# 方式1直接指定年月日ddate(2026,4,19)print(d)# 2026-04-19print(type(d))# class datetime.date# 方式2获取当前日期todaydate.today()print(today)# 2026-04-19# 方式3从时间戳创建importtime timestamptime.time()ddate.fromtimestamp(timestamp)print(d)# 2026-04-19# 方式4从 ISO 格式字符串创建Python 3.7ddate.fromisoformat(2026-04-19)print(d)# 2026-04-193.2 date 属性和方法fromdatetimeimportdate ddate(2026,4,19)# 属性print(f年:{d.year})# 2026print(f月:{d.month})# 4print(f日:{d.day})# 19# 方法print(f替换:{d.replace(month5)})# 2026-05-19print(f时间元组:{d.timetuple()})# struct_timeprint(f序号:{d.toordinal()})# 从公元1年1月1日的天数print(f星期0周一:{d.weekday()})# 6周日print(f星期1周一:{d.isoweekday()})# 7周日print(fISO格式:{d.isoformat()})# 2026-04-19print(fCTime格式:{d.ctime()})# Sun Apr 19 00:00:00 2026print(f格式化:{d.strftime(%Y年%m月%d日)})# 2026年04月19日3.3 星期对照表方法周一周二周三周四周五周六周日weekday()0123456isoweekday()12345674. time 类时间4.1 创建 time 对象fromdatetimeimporttime# 基本创建ttime(14,30,15,500000)# 时、分、秒、微秒print(t)# 14:30:15.500000# 最小参数ttime(14,30)# 14:30:00print(t)# 14:30:00# 从 ISO 格式字符串创建Python 3.7ttime.fromisoformat(14:30:15.5)print(t)# 14:30:15.5000004.2 time 属性和方法fromdatetimeimporttime ttime(14,30,15,500000)# 属性print(f时:{t.hour})# 14print(f分:{t.minute})# 30print(f秒:{t.second})# 15print(f微秒:{t.microsecond})# 500000# 方法print(f替换:{t.replace(hour10)})# 10:30:15.500000print(fISO格式:{t.isoformat()})# 14:30:15.500000print(f格式化:{t.strftime(%H点%M分)})# 14点30分4.3 time 的 tzinfo 参数fromdatetimeimporttime,timezone# 创建带时区的时间utc_timetime(14,30,tzinfotimezone.utc)print(utc_time)# 14:30:0000:00print(utc_time.tzname())# UTC5. datetime 类日期 时间5.1 创建 datetime 对象fromdatetimeimportdatetime,timezoneimporttime# 方式1直接指定dtdatetime(2026,4,19,14,30,15,500000)print(dt)# 2026-04-19 14:30:15.500000# 方式2获取当前时间nowdatetime.now()# 本地时间print(now)# 2026-04-19 09:30:00.123456utc_nowdatetime.now(timezone.utc)# UTC 时间print(utc_now)# 2026-04-19 01:30:00.12345600:00# 方式3从时间戳创建timestamptime.time()dtdatetime.fromtimestamp(timestamp)print(dt)# 2026-04-19 09:30:00.123456# 方式4组合 date 和 timeddate(2026,4,19)ttime(14,30,15)dtdatetime.combine(d,t)print(dt)# 2026-04-19 14:30:15# 方式5从 ISO 格式字符串创建dtdatetime.fromisoformat(2026-04-19T14:30:15)print(dt)# 2026-04-19 14:30:15# 方式6从字符串解析dtdatetime.strptime(2026-04-19 14:30:15,%Y-%m-%d %H:%M:%S)print(dt)# 2026-04-19 14:30:155.2 datetime 属性和方法fromdatetimeimportdatetime dtdatetime(2026,4,19,14,30,15,500000)# 属性包含 date 和 time 的所有属性print(f年:{dt.year})print(f月:{dt.month})print(f日:{dt.day})print(f时:{dt.hour})print(f分:{dt.minute})print(f秒:{dt.second})print(f微秒:{dt.microsecond})# 方法print(f日期部分:{dt.date()})# 2026-04-19print(f时间部分:{dt.time()})# 14:30:15.500000print(f时间部分有时区:{dt.timetz()})print(f替换:{dt.replace(month5)})# 2026-05-19 14:30:15.500000print(f星期0周一:{dt.weekday()})print(f星期1周一:{dt.isoweekday()})print(fISO格式:{dt.isoformat()})# 2026-04-19T14:30:15.500000print(f时间戳:{dt.timestamp()})print(fCTime格式:{dt.ctime()})# Sun Apr 19 14:30:15 20266. timedelta 类时间差6.1 创建 timedelta 对象fromdatetimeimporttimedelta# 可以使用的参数tdtimedelta(days1,seconds3600,microseconds500,milliseconds100,minutes30,hours2,weeks1)print(td)# 8 days, 3:30:00.000500# 常用创建方式daytimedelta(days1)# 1 day, 0:00:00hourtimedelta(hours1)# 1:00:00minutetimedelta(minutes1)# 0:01:00secondtimedelta(seconds1)# 0:00:01weektimedelta(weeks1)# 7 days, 0:00:006.2 timedelta 属性和方法fromdatetimeimporttimedelta tdtimedelta(days5,hours3,minutes30,seconds15)# 属性归一化后的值print(f天数:{td.days})# 5print(f秒数部分:{td.seconds})# 12615 (3*3600 30*60 15)print(f微秒部分:{td.microseconds})# 0# 方法print(f总秒数:{td.total_seconds()})# 5*86400 12615 444615.06.3 timedelta 运算fromdatetimeimportdatetime,timedelta nowdatetime.now()# 加法未来时间tomorrownowtimedelta(days1)next_weeknowtimedelta(weeks1)next_hournowtimedelta(hours1)# 减法过去时间yesterdaynow-timedelta(days1)last_weeknow-timedelta(weeks1)# 两个 timedelta 运算td1timedelta(days5,hours3)td2timedelta(days2,hours5)print(td1td2)# 7 days, 8:00:00print(td1-td2)# 2 days, 22:00:00print(td1*2)# 10 days, 6:00:00print(td1/2)# 2 days, 13:30:007. timezone 类时区fromdatetimeimportdatetime,timezone,timedelta# UTC 时区utctimezone.utcprint(utc)# UTC# 自定义偏移时区beijing_tztimezone(timedelta(hours8))print(beijing_tz)# UTC08:00# 创建带时区的 datetimenow_utcdatetime.now(timezone.utc)now_beijingdatetime.now(beijing_tz)print(fUTC:{now_utc})print(f北京时间:{now_beijing})8. 综合示例fromdatetimeimportdate,time,datetime,timedelta,timezoneprint(*50)print(datetime 模块综合示例)print(*50)# 1. 创建各种对象print(\n1. 创建对象)ddate(2026,4,19)ttime(14,30,15)dtdatetime(2026,4,19,14,30,15)tdtimedelta(days7)print(f日期:{d})print(f时间:{t})print(f日期时间:{dt})print(f时间差:{td})# 2. 获取当前时间print(\n2. 获取当前时间)print(f当前日期:{date.today()})print(f当前日期时间:{datetime.now()})print(fUTC 时间:{datetime.now(timezone.utc)})# 3. 时间运算print(\n3. 时间运算)nowdatetime.now()week_laternowtimedelta(weeks1)diffweek_later-nowprint(f现在:{now})print(f一周后:{week_later})print(f时间差:{diff})print(f总秒数:{diff.total_seconds()})# 4. 提取各部分print(\n4. 提取日期时间各部分)dtdatetime(2026,4,19,14,30,15)print(f完整:{dt})print(f年:{dt.year}, 月:{dt.month}, 日:{dt.day})print(f时:{dt.hour}, 分:{dt.minute}, 秒:{dt.second})print(f星期:{dt.strftime(%A)})# 5. 字符串解析print(\n5. 字符串解析与格式化)date_str2026-04-19 14:30:15dt_parseddatetime.strptime(date_str,%Y-%m-%d %H:%M:%S)print(f解析:{dt_parsed})print(f格式化:{dt_parsed.strftime(%Y年%m月%d日 %H时%M分%S秒)})9. 常见问题问题解决方案datetime(2026, 13, 1)报错月份必须在 1-12 之间datetime(2026, 4, 32)报错天数必须在有效范围内naive 和 aware 比较报错统一转换为同一类型时区转换错误使用astimezone()方法10. 总结类核心用途常用方法date处理日期today(),weekday(),replace()time处理时间replace(),isoformat()datetime处理日期时间now(),strptime(),strftime()timedelta处理时间差total_seconds()timezone处理时区utc常量

相关文章:

09-扩展知识——02. 初识 datetime 模块

02. 初识 datetime 模块 概述 datetime 是 Python 处理日期和时间的核心模块,提供了 date、time、datetime、timedelta、tzinfo 五个主要类。掌握这个模块是时间处理的基础。维度内容Whatdatetime 模块的五大核心类及其基本用法Why日常日期时间操作的首选模块When需…...

利用 workbuddy 小龙虾 对CodeBuddy开发历史对话 进行开发总结 提高以后的开发效果

利用 workbuddy 小龙虾 对CodeBuddy开发历史对话 进行开发总结 提高以后的开发效果 提示词 你能读取 CodeBuddy CN.历史记录吗 "C:\Users\yang\AppData\Local\Programs\CodeBuddy CN\CodeBuddy CN.exe" 和 F:\Programs\CodeBuddy\CodeBuddy.exe 每一个对话框 都总结…...

别再只用默认密码了!手把手教你用Hydra和Burp Suite搞定SSH、Web后台的弱口令检测(附实战避坑指南)

企业安全自查实战:Hydra与Burp Suite弱口令检测全流程解析 当你的服务器突然被植入挖矿程序,或是客户数据在暗网明码标价出售时,80%的情况都始于一个被忽视的弱口令。这不是危言耸听——2023年Verizon数据泄露调查报告显示,弱口令…...

别再只接SWDIO和SWCLK了!STM32 SWD下载电路完整接线指南(含NRST、3.3V、GND详解)

STM32 SWD调试接口全解析:从基础接线到高速信号完整性设计 引言 第一次使用ST-Link给STM32下载程序时,我也曾天真地以为只要连接SWDIO和SWCLK两根线就够了。结果在连续三次下载失败后,我才意识到自己犯了一个典型的新手错误——忽略了完整的S…...

锁相环(PLL)核心原理、设计调试与应用场景全解析

1. 从“锁相”到“锁频”:一个经典电路的深度拆解如果你在通信、数字电路或者射频领域摸爬滚打过几年,那么“锁相环”这三个字对你来说,绝对不是一个陌生的概念。它就像电路世界里的瑞士军刀,从你手机里的射频收发器,到…...

Myco:为AI智能体设计的“活”认知基板,实现可持续知识管理

1. 项目概述:Myco,一个为AI智能体而生的“活”认知基板如果你和我一样,在过去一年里频繁地在LangChain、LangGraph、CrewAI、DSPy这些框架之间切换,每次新框架发布都意味着一次痛苦的迁移和重构,那么你一定能理解那种“…...

液压风力涡轮机:用流体传动重构风电系统架构的工程实践

1. 风力发电的“常规”与“另类”:为什么我们要重新审视机舱设计?干这行十几年,跟各种发电设备打交道,风力涡轮机算是老朋友了。大家现在看到的绝大多数风电机组,结构都差不多:高高的塔筒顶上,有…...

科技晚报|2026年5月8日:AI 开始争夺默认入口与治理层

科技晚报|2026年5月8日:AI 开始争夺默认入口与治理层 一句话导读:今晚最值得看的,不是哪家又把模型做大了一点,而是谁正在把 AI 变成默认入口和默认配置。Google 把 Fitbit 升级成 Google Health 并接入 Gemini 教练&a…...

别把 `temperature`、`top-k`、`top-p`、`beam search` 当成四个并列旋钮:很多生成问题,先调错的是“分布”还是“搜索”

别把 temperature、top-k、top-p、beam search 当成四个并列旋钮:很多生成问题,先调错的是“分布”还是“搜索” 很多人一看到模型输出太飘、太保守,第一反应就是一起改 temperature、top-k、top-p,最后再顺手试 beam search。但这四个名字根本不在同一层:前三个改的是下…...

在 Taotoken 控制台回顾与分析团队月度大模型用量消耗

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 在 Taotoken 控制台回顾与分析团队月度大模型用量消耗 对于项目管理者或团队负责人而言,清晰、透明地掌握大模型 API 的…...

硬件开发如何对抗延迟:构建高速度创新体系的策略与实践

1. 项目概述:当“延迟”成为创新的头号杀手在硬件工程和半导体设计领域,我们常常陷入一个误区:认为项目的成败取决于一个绝妙的架构、一颗顶级的芯片,或是一支由天才工程师组成的团队。然而,二十多年的从业经验告诉我&…...

基于云端OpenClaw的情绪互动机器人系统-Milk-V Duo S + 机器人 端开发(5)

上周我打通了Milk-V Duo S和机器人的串口控制的脉络,同时制作了两个动作组:下蹲、自由飞翔。 阶段状态环境搭建✅ 完成网络配置✅ 完成串口控制✅ 完成动作调度✅ 完成序列执行控制✅ 完成时间控制✅ 完成部分动作组制作✅ 完成线程执行锁✅ 完成云端接…...

力扣-最后一个单词长度(58)

重点:1.循环初始值:注意不能越界。如果直接取字符串长度则下标会溢出,所以要减1.2.循环条件:注意等于号,i >0,等号不成立的话会遗漏没有空格的情况3.循环中判断条件:考虑字符串最后面为空格的情况。clas…...

如何使用AI从文档中准确提取所有内容

如何使用AI从文档中准确提取所有内容 作者:AI拉呱(Errol Yan) 定位:AI领域深度内容与实战方法分享 TL;DR 文档解析器在处理现实文档中常见的复杂布局时面临困难,例如具有合并单元格的表格、跨页符号和错位的文本。此外,大量信息存在于图表或图形中,需要准确提取。本文将…...

Arm Cortex-A720 PMU与多核功耗管理实战解析

1. Cortex-A720 PMU架构解析在嵌入式系统开发中,性能监控单元(PMU)如同汽车的仪表盘,为开发者提供处理器运行状态的实时数据。Arm Cortex-A720的PMU架构采用内存映射寄存器设计,通过硬件计数器实现指令周期、缓存命中率等关键指标的采集。与早…...

别再瞎调WPF Grid布局了!Auto和*的实战用法,看完这篇就够了

WPF Grid布局实战:用Auto和*构建自适应界面的黄金法则 刚接触WPF开发时,我总被各种布局容器搞得晕头转向。直到有次接手一个企业级后台系统,在连续加班三天解决界面错位问题后,才真正明白Grid布局中Auto和的精妙配合有多重要。不同…...

Spring 参数验证使用示例(基于 RuoYi 项目)

一、触发方式 进入系统管理 → 角色管理,点新增,在权限字符里填入超过100个字符的内容,点确定。 二、前端现象 2.1 页面报错提示 前端弹出红色提示框,显示"权限字符长度不能超过100个字符"。 2.2 HTTP 请求信息 从浏…...

智象科技AI数智员工:重构运维效率的智能引擎

在企业数字化转型不断深入的今天,运维体系正从“被动响应”走向“智能驱动”。智象科技基于大语言模型与数据智能能力,推出全新“AI数智员工”,以“全栈智能协同”为核心理念,构建覆盖感知、分析、决策与执行的智能运维闭环&#…...

大模型---LangGraph的循环与迭代

目录 1.LangGraph的循环 2.典型的迭代方式 3.循环退出条件 1.LangGraph的循环 LangGraph的循环可以分为3个部分:① State:保存迭代过程中的状态,② node:每轮执行的逻辑,③ conditional edge:判断继续循环还是结束。 最简单的循环方法就是固定迭代次数,即让一个节点…...

马拦过河卒

棋盘上A点有一个过河卒,需要走到目标B点。卒行走的规则:可以向下、或者向右。同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点。因此称之为“马拦过河卒”。 棋盘用坐标表示,A点&#xff08…...

软考中级数据库系统工程师考试大纲

数据库系统工程师考试大纲一、考 试 说 明1.考试目标通过本考试的合格人员能参与信息系统的规划、设计、 构建、运行和管理,能按照用户需求,设计、建立、运行、 维护数据库系统;能管理信息系统中的数据资源,建立和维 护…...

关于hopfield 网络和受限玻尔兹曼机,其如何为现代深度学习奠基?

0 感知机、hopfield网络、受限玻尔兹曼机、mlp之间的历史关系 近几年入门深度学习的大多数学习者,可能已经很少听说hopfield网络、受限玻尔兹曼机了,很多书籍和博客在讲解深度学习基础的时候也只会讲到感知机和mlp这种结构,而提及hopfield网…...

SON自动添加邻站功能

该功能主要依赖于ANR自动添加邻区。在邻区添加完成后,源基站会从邻区的CGI信息中解析出目标基站的eNB ID,然后向核心网(MME)发送一条eNB Configuration Transfer消息,用于请求该eNB ID对应的X2接口传输层地址。若核心网…...

普通机床改造成键槽铣床

普通机床在机械加工领域应用广泛,但功能相对单一,若想拓展其加工范围,将其改造成键槽铣床是个不错的选择。改造的核心在于通过加装特定部件,让机床具备铣削键槽的能力。普通机床原本的直线运动和旋转运动基础,为改造提…...

如何高效阅读c语言函数(形成线思维和面思维)

最近,我在阅读linux内核源码,由于代码量太大了,有成百个源文件,源文件中有成千上万的函数,我本来的计划是对每一个源文件中的函数自上而下粗略读一遍(不会跳转到子函数中去看子函数是如何实现的&#xff09…...

机器学习40讲-10:特征预处理

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程​​​https://www.captainai.net/troubleshooter 华盛顿大学教授、《终极算法》(The Master Algorithm)的作者佩德罗多明戈斯曾在Communications of The ACM…...

探讨CSS复合属性的实际应用与交互设计

在CSS中,我们经常使用到的一些复合属性包括:font(字体)、border(边框)、background(背景)、padding(内边距)以及margin(外边距)等。接…...

常用代码知识

一、算法题常用 1.1 CSTL中哈希表(std::unordered_map和std::unordered_multimap) unordered_map和unordered_multimap区别在与mult的值可以重复。 方法insert、erase、size、count(统计出现次数) 其他操作: unorder…...

当AI写小说——一个被严重低估的工程化战场

当AI写小说——一个被严重低估的工程化战场本文收录于《工程化AI人机协同方法论》系列专栏,对应系列第54篇核心文章 核心结论前置:AI写小说从来不是「一句prompt生成全文」的创意魔法,而是一套涵盖设定治理、记忆管理、文风校准、节奏管控、合…...

3401黄大年茶思屋榜文保姆级全落地解法「34期 1题」全系统可编程安全易用高效统一架构重构与原约束双路径落地解法

华夏之光永存・开源:黄大年茶思屋榜文保姆级全落地解法「34期 1题」 小标题:全系统可编程安全易用高效统一架构重构与原约束双路径落地解法 一、摘要 全系统可编程赛道当下全球现代工程技术已触达绝对性能天花板,现有eBPF、Wasm分立方案、传统内核可编程框架、常规工具链…...