Python日期带时区转换工具类总结
文章目录
- 1.背景
- 2. 遇到的坑
- 3. 一些小案例
- 3.1 当前日期、日期时间、UTC日期时间
- 3.2 昨天、昨天UTC日期、昨天现在这个时间点的时间戳
- 3.3 日期转时间戳
- 3.4 时间戳转日期
- 3.5 日期加减、小时的加减
- 4. 总结
- 5. 完整的编码
1.背景
最近项目是国际项目,所以需要经常需要用到UTC时间和local时间的转换。
所以整理了一下时间戳工具类,方便使用。
这里主要用到的包就是datatime、time、pytz。
2. 遇到的坑
直接看测试案例
tzinfo=pytz.timezone("Asia/Shanghai")
dtStr = "2023-05-28 00:00:00"
dt1 = datetime.datetime.strptime(dtStr,"%Y-%m-%d %H:%M:%S").replace(tzinfo=tzinfo)
dt2 = dt_tz = tzinfo.localize(datetime.datetime.strptime(dtStr, '%Y-%m-%d %H:%M:%S'))
print(dt1)
print(dt2)
输出结果:
2023-05-28 00:00:00+08:06
2023-05-28 00:00:00+08:00
这里第一种方法dt1中的输出时区带有06分的差异。
关于这个误差查找到的相关解释:

3. 一些小案例
3.1 当前日期、日期时间、UTC日期时间
print(DateUtil.currDate())
print(DateUtil.currDateTime())
print(DateUtil.currDateTime("UTC"))
输出结果:
2023-05-29
2023-05-29 10:44:27
2023-05-29 02:44:27
3.2 昨天、昨天UTC日期、昨天现在这个时间点的时间戳
print(DateUtil.yesterday())
print(DateUtil.yesterdayUTC())
print(DateUtil.yesterday_ts())
输出结果:
2023-05-28
2023-05-28 #这里如果是早上8点以前运行的就不一样
1685242026391
3.3 日期转时间戳
print(DateUtil.date2ts("2023-05-28"))
print(DateUtil.datetime2ts("2023-05-28 10:01:01"))
print(DateUtil.datetime2ts("2023-05-28 10:01:01","UTC"))
print(DateUtil.datetime2ts("2023-05-28 10:01:01","Asia/Shanghai"))
输出结果:
1685203200000
1685239261000
1685268061000 #如果使用的是UTC格式,则时间戳不一样
1685239261000
3.4 时间戳转日期
print(DateUtil.timestamp2Date("1685239261000"))
print(DateUtil.timestamp2Date("1685239261")) # 这里自动判断是毫秒还是秒
print(DateUtil.timestamp2Date("1685239261","UTC")) # 这里指定输出的日期的时区是UTC格式
print(DateUtil.timestamp2Date(1685239261)) #int类型或者字符串都可以转行
print(DateUtil.timestamp2Date(1685239261000,"UTC")) #int类型或者字符串都可以转行
输出结果:
2023-05-28 10:01:01
2023-05-28 10:01:01
2023-05-28 02:01:01
2023-05-28 10:01:01
2023-05-28 02:01:01
3.5 日期加减、小时的加减
print(DateUtil.dateAdd("2023-05-28",1)) #加
print(DateUtil.dateAdd("2023-05-28",-1)) #减
print(DateUtil.datetimeAdd("2023-05-28 10:01:01",-1)) #日期时间的加减
print(DateUtil.hourAdd("2023-05-28 10:01:01",1)) # 小时的加减
print(DateUtil.hourAdd("2023-05-28 10:01:01",-1)) # 小时的加减
输出结果:
2023-05-29
2023-05-27
2023-05-27 10:01:01
2023-05-28 11:01:01
2023-05-28 09:01:01
4. 总结
刚开始思绪有点乱,刚好趁机会好好的整理了一遍思路。
注意: 当使用日期进行格式转换时,需要确定这个日期对应的时区。
- 时区的设置
python的日期中时区对应的有个属性timezone。
我这里主要是通过pytz.timezone(“时区字符串”)来设置时区的。
比如,要将日期转为时间戳,首先要指定这个日期的时区属性。
tzinfo = pytz.timezone("Asia/Shanghai")
- 日期设置
然后通过localize方法配置这个日期的时区。
dt_tz = tzinfo.localize(dt)
再进行其他的转换。
但是千万要注意,不要使用datetime中的.replace方法来设置时区。
# 这样设置会导致会导致输出结果`2023-05-28 00:00:00+08:06` 带有一个6分钟的差异
dt_tz =datetime.datetime.strptime("2023-05-28 00:00:00","%Y-%m-%d %H:%M:%S").replace(tzinfo=tzinfo)
5. 完整的编码
# -*- coding: utf-8 -*-
# @Time : 2023/3/28 10:04
# @Author : King
# @Software: PyCharm
# @Describe:
# -*- encoding:utf-8 -*-
import datetime
import time,pytz_timezone_utc = "UTC"
_timezone_cn = "Asia/Shanghai""""
DateTime日期转时间戳(日期时区为上海)
"""
def datetime2ts(date, timezone=_timezone_cn):if isinstance(date, datetime.datetime):return int(date.timestamp() * 1000)else:date = date + " 00:00:00" if len(date) <= 10 else datedt = datetime.datetime.strptime(date, '%Y-%m-%d %H:%M:%S')dt_tz = pytz.timezone(timezone).localize(dt)return int(dt_tz.timestamp()*1000)"""
DateTime日期转时间戳(日期时区为UTC)
"""
def utcDatetime2ts(date):return datetime2ts(date,_timezone_utc)"""
Date日期转时间戳
"""
def date2ts(date,timezone=_timezone_cn):if isinstance(date,datetime.datetime):return int(date.timestamp()*1000)else:dt = datetime.datetime.strptime(date, '%Y-%m-%d')dt_tz = pytz.timezone(timezone).localize(dt)return int(dt_tz.timestamp()*1000)"""
时间戳转日期
"""
def _ts2Date(timestamp,timezone,date_format="%Y-%m-%d %H:%M:%S"):tz = pytz.timezone(timezone)timestamp_s = int(timestamp) if len(str(timestamp)) <= 10 else int(timestamp)/1000dt_tz = datetime.datetime.fromtimestamp(timestamp_s,tz)return dt_tz.strftime(date_format)"""
时间戳转日期
"""
def timestamp2Date(timestamp,timezone=_timezone_cn):return _ts2Date(timestamp,timezone)"""
获取当前日期 2023-03-28
"""
def currDate(timezone=_timezone_cn):return datetime.datetime.now(pytz.timezone(_timezone_utc)).astimezone(pytz.timezone(timezone)).strftime('%Y-%m-%d')
"""
当前UTC日期
"""
def currUTCDate():return datetime.datetime.now(pytz.timezone(_timezone_utc)).strftime('%Y-%m-%d')"""
昨日
"""
def yesterday(timezone=_timezone_cn):return dateAdd(currDate(timezone),-1)
"""
UTC昨日
"""
def yesterdayUTC():return dateAdd(currUTCDate(),-1)
"""
当前日期时间
"""
def currDateTime(timezone=_timezone_cn):return datetime.datetime.now(pytz.timezone(timezone)).strftime('%Y-%m-%d %H:%M:%S')"""
当前时间戳
"""
def currTimestamp():return int(time.time()*1000)"""
昨天时间戳
"""
def yesterday_ts():return currTimestamp() - 24*3600*1000"""
日期的增减
"""
def dateAdd(date, n):dt = datetime.datetime.strptime(date, "%Y-%m-%d")return (dt + datetime.timedelta(days=n)).strftime("%Y-%m-%d")
"""
日期时间的增减
"""
def datetimeAdd(date,n):dt = datetime.datetime.strptime(date,'%Y-%m-%d %H:%M:%S')return (dt + datetime.timedelta(days=n)).strftime('%Y-%m-%d %H:%M:%S')"""
小时的增减
"""
def hourAdd(date,n):dt = datetime.datetime.strptime(date, '%Y-%m-%d %H:%M:%S')return (dt + datetime.timedelta(hours=n)).strftime('%Y-%m-%d %H:%M:%S')"""
timezone:默认是Aisa/Shanghai时区
指定日期的上一个小时的时间戳
"""
def lastHourTimestamp(date,timezone=_timezone_cn):if(len(date) == 10):ts = date2ts(date,timezone)else:ts = datetime2ts(date,timezone)return ts - ts % 3600000 - 3600*1000相关文章:
Python日期带时区转换工具类总结
文章目录 1.背景2. 遇到的坑3. 一些小案例3.1 当前日期、日期时间、UTC日期时间3.2 昨天、昨天UTC日期、昨天现在这个时间点的时间戳3.3 日期转时间戳3.4 时间戳转日期3.5 日期加减、小时的加减 4. 总结5. 完整的编码 1.背景 最近项目是国际项目,所以需要经常需要用…...
视频会议产品对比分析
内网视频会议系统如何选择?有很多单位为了保密,只能使用内部网络,无法连接互联网,那些SaaS视频会议就无法使用。在内网的优秀视频会议也有很多可供选择,以下是几个常用的: 1. 宝利通:它支持多种…...
每日一练 | 华为认证真题练习Day47
1、某台路由器输出信息如下,下列说法错误的是?(多选) A. 本路由器开启了区域认证 B. 本设备出现故障,配置的Router Id和实际生效的Router ID不一致 C. 本设备生效的Router Id为10.0.12.1 D. 本设备生效的Router Id为…...
ChatIE(LLM大模型用于信息抽取)
Zero-Shot Information Extraction via Chatting with ChatGPT paper:https://arxiv.org/abs/2302.10205 利用ChatGPT实现零样本信息抽取(Information Extraction,IE),看到零样本就能大概明白这篇文章将以ChatGPT作为…...
提升企业管理效率的利器——ADManager Plus
在当今信息时代,企业的规模和复杂性不断增长,管理各个方面变得愈发具有挑战性。而在企业管理中,活跃目录(Active Directory)起着至关重要的作用。它是一种用于组织内部的用户、计算机、组和其他对象进行集中管理的目录…...
《入侵的艺术》读书心得:第六章:渗透测试中的智慧与愚昧
第六章:渗透测试中的智慧与愚昧 这些想法是愚昧的 1.任何期待渗透测试结果是“毫无破绽”、“无懈可击”…都是极其愚昧的: 第一层含义:测试的不可穷尽性原理(同软件测试) 第二层含义:作为优秀甚至只是合…...
SAP-MM-采购申请-价值特性
采购申请审批在维护价值特性时要注意是抬头价值还是行价值,要确定选择哪个,配置时对应配置。 1、创建价值特性CT04 字段名称:CEBAN-GSWRT,和CEBAN-GFWRT 抬头总价值:CEBAN-GFWRT;如果选择的是抬头审批&am…...
设计模式 - 代理模式
基本介绍: 代理模式:为一个对象提供一个替身,以控制对这个对象的访问。即通过代理 对象访问目标对象.这样做的好处是:可以在目标对象实现的基础上,增强额外的 功能操作,即扩展目标对象的功能。被代理的对象可以是远程对象、创建开销大的对象或需要安全控…...
IOC初始化 IOC启动阶段 (Spring容器的启动流程)
[toc](IOC初始化 IOC启动阶段 (Spring容器的启动流程)) IOC初始化 IOC启动阶段 (Spring容器的启动流程) Resource定位过程:这个过程是指定位BeanDefinition的资源,也就是配置文件(如xml)的位置,并将其封装成Resource对…...
Java后端入职第四天,就被要求代码回退(Git回退实战)
一、需求背景 初入职场,由于自己的失误或者对git不熟悉,把被人的代码给冲突掉了,然后需要立马回滚,对于新手开发,应该比较常见吧!或者,比较多一种情况,错误把工程add了到了暂存区,比如一些本地配置,本来就不应该提交的,又或者,开发中只提交部分代码,又想最新的提…...
【swing】SplitPanel
当使用Java的Swing库来实现一个左右风格的SplitPanel时,可以使用JSplitPane作为容器,并在左边的面板中放置三个按钮,以及在右边的面板中显示图片。以下是一个示例代码: import javax.swing.*; import java.awt.*; import java.aw…...
网络货运平台源码 管理平台端+司机端APP+货主端APP源码
网络货运平台系统源码,网络货运平台源码 管理平台端司机端APP货主端APP 遵循政策要求的八项基本功能,结合货主、实际承运人、监管方等多方业务场景,构建人、车、货、企一体的标准化网络货运平台系统。具有信息发布、线上交易、全程监控、金融…...
Yarn学习笔记
Apache Hadoop YARN (Yet AnotherResource Negotiator,另一种资源协调者)是一种新的 Hadoop 资源管理器,它是一个通用资源管理系统,可为上层应用提供统一的资源管理和调度,它的引入为集群在利用率、资源统一…...
智能路由器开发之OpenWrt简介
智能路由器开发之OpenWrt简介 1. 引言 1.1 智能路由器的重要性和应用场景 智能路由器作为网络通信的核心设备,具有重要的地位和广泛的应用场景。传统的路由器主要提供基本的网络连接功能,但随着智能家居、物联网和大数据应用的快速发展,对于…...
Linux音频和视频命令速查表
在Linux系统中,有许多命令可以帮助我们处理音频和视频文件,从基本的播放和转码,到编辑和处理音频、视频流。 本文将提供一个Linux音频和视频命令速查表,帮助您快速查找并了解各种常用的命令及其用法。 音频命令 播放音频文件 a…...
脉蜂:Django + Flutter 开发的进销存管理系统【已开源】
项目说明 小规模零售(包括电商)跟大规模零售企业的差别在哪里呢? 以我当前的认知来看,小规模零售跟大规模零售企业的差别更多的是在供应链管理、进销存管控上面产生的。如果有一个工具,能够帮他们减少这方面的差异&…...
树的先序,中序,后序递归遍历
//树的先序、中序、后序遍历递归 #include<bits/stdc.h> typedef struct node { char data; struct node *lchild,*rchild; }BTNode; void Greate(BTNode *&T) { char ch; scanf("%c",&ch); if(ch#) TNULL; else { T(BTNode*)malloc(sizeof(BT…...
如何在Linux中更改SSH端口?
SSH(Secure Shell)是一种安全的远程登录协议,它允许您通过网络远程连接到Linux系统并进行管理操作。默认情况下,SSH使用22端口进行通信。然而,为了增强系统的安全性,有时候我们需要更改SSH端口,…...
合创视觉科技UI设计师就业发展前景怎么样?薪资待遇如何?
UI简介 用户界面(简称UI,亦称使用者界面)是系统和用户之间进行交互和信息交换的媒介,它实现信息的内部形式与人类可以接受形式之间的转换。用户界面是介于用户与硬件而设计彼此之间交互沟通相关软件,目的在使得用…...
VB一个可以改变箭头方向的气泡提示
新建一个类名。名称为clsTip Option Explicit * 模块名称:clsTip.cls * 功能:一个可以改变箭头方向的气泡提示类 Private Type TOOLINFO cbSize As Long dwFlags As Long hwnd As Long dwID As Long rtRect(3) As Long hInst As Long lpszText As String…...
神经符号系统实践:耦合机器学习与本体论提升机器人自主诊断能力
1. 项目概述:当机器学习遇见本体论 在机器人圈子里摸爬滚打十几年,我见过太多“聪明”但“不可靠”的自主系统。它们能精准识别物体、规划路径,但一旦遇到训练数据之外的场景,或者传感器出现一点小毛病,行为就可能变得…...
智能电表数据填补技术对比:从Holt-Winters到Time-MoE的实战指南
1. 项目概述:当智能电表数据“断片”时,我们如何“脑补”?在能源管理和智能电网的日常运维中,我们这些从业者最头疼的问题之一,就是拿到手的智能电表数据“缺斤短两”。想象一下,你正试图分析一个居民区的用…...
机器学习势函数与元动力学模拟:揭示电催化水分解的原子尺度反应机理
1. 项目概述:当机器学习势函数遇上电催化水分解 在电催化水分解这个充满前景的清洁能源技术领域,析氧反应(OER)一直是个“老大难”问题。它发生在电解池的阳极,需要将水分子高效地拆解成氧气、质子和电子。这个过程的效…...
机器学习增强无导数优化:Sobolev学习与代理模型实践
1. 项目概述与核心思路在工程优化、材料设计乃至金融建模中,我们常常会遇到一类“黑箱”问题:你有一个复杂的仿真程序或物理实验,输入一组参数,它能吐出一个结果(比如性能指标、成本或误差),但你…...
告别Cygwin!用Windows版MRT一键批量拼接MODIS影像(附详细配置流程)
告别Cygwin!Windows版MRT全流程实战:MODIS影像批量拼接指南 遥感数据处理的门槛正在被技术进步不断拉低。曾几何时,在Windows系统下处理MODIS数据意味着必须忍受Cygwin这类Linux模拟环境的笨重与兼容性问题——环境配置复杂、命令操作反直觉、…...
基于伴随方法与Firedrake的PDE-ML可微分集成框架
1. 项目概述:当有限元遇上机器学习在计算科学与工程领域,我们常常面临一个核心挑战:如何高效地求解复杂的物理系统,并在此基础上进行优化、反演或设计。偏微分方程(PDE)是描述这些物理系统(如流…...
别再让WSL2吃光你的C盘!手把手教你迁移到D盘并优化内存配置(Windows10/11通用)
WSL2系统迁移与性能调优全指南:释放C盘空间与提升运行效率 每次打开资源管理器看到C盘剩余空间不足10%的红色警告,作为开发者的你是否感到一阵窒息?WSL2虽然为Windows带来了原生的Linux体验,但默认安装配置却可能成为系统资源的&q…...
知识图谱与大语言模型协同:构建材料科学精准智能问答系统
1. 项目概述:当知识图谱遇见大语言模型“想象一下,未来有这样一个设备……个人可以存储他所有的书籍、记录和通信,并且它被机械化,可以以极高的速度和灵活性进行查阅。它是他记忆的一个放大的、亲密的补充。”——范内瓦布什&…...
Tomcat隐藏Server响应头的三种实战方案
1. 为什么连Tomcat默认的版本号都得藏起来?你有没有在浏览器开发者工具的Network面板里,随手点开一个Java Web应用的响应头,就看到这么一行:Server: Apache-Coyote/1.1或者更直白的Server: Apache Tomcat/9.0.83?我第一…...
CSS Grid布局深入解析:掌握现代布局技术
CSS Grid布局深入解析:掌握现代布局技术 引言 CSS Grid布局是CSS3引入的强大布局系统,它提供了一种二维网格布局方式,可以轻松实现复杂的页面布局。本文将深入探讨Grid布局的核心概念、高级技巧和最佳实践。 一、Grid布局基础 1.1 Grid容器与…...
