将utc转换为python中的est时间



我有两个日期,开始日期和结束日期,其中都需要在谷歌标签管理器中使用EST时区使用python。

目前,当我使用api从jira获取日期时,我正在获得UTC格式的开始日期,但对于结束日期,只获得日期值,也在类str中类型。

This is what I got from jira
start date: 2021-09-20T07:16:08.000+0000
end date: 2021-09-21

现在我需要转换这些并使用python gtm api创建一个标记,其中开始和结束日期应该在EST时区。

开始日期中的时间应为00:00:00,结束日期中的时间应为23:59:59(均为EST时间)

有谁能帮我一下吗?

如果我理解正确的话,这两个字符串都是这样得到的吗?

startdate = "start date: 2021-09-20T07:16:08.000+0000"
enddate = "end date: 2021-09-21"

然后首先你要做的是,在空格上分割并选择最后一项

justStartDatetimeString = startdate.split(" ")[-1]
justEndDatetimeString = enddate.split(" ")[-1]

如果你只是像这样得到datetime作为字符串,忽略上面的部分:

"2021-09-20T07:16:08.000+0000"

现在只需使用dateutil.parser

将其解析为日期时间
from datetime import datetime, time, timezone
import dateutil.parser 
startdateDateTime = dateutil.parser.isoparse(justStartDatetimeString)
startdateDateTime = startdateDateTime.replace(tzinfo=timezone.utc).astimezone(tz=dateutil.tz.gettz('US/Eastern'))
startdateDateTime = startdateDateTime.replace(hour=0, minute=0, second=0)

对于结束日期字符串

enddateDateTime = dateutil.parser.isoparse(justEndDatetimeString)
enddateDateTime = enddateDateTime.replace(tzinfo=dateutil.tz.gettz('US/Eastern'))astimezone(tz=dateutil.tz.gettz('US/Eastern'))
enddateDateTime = enddateDateTime.replace(hour=23, minute=59, second=59)

最新更新