首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Powershell解析日期ISO8601

Powershell解析日期ISO8601
EN

Stack Overflow用户
提问于 2020-02-12 10:50:12
回答 2查看 1.9K关注 0票数 0

我有一个我认为是ISO8601格式的日期字符串(虽然我不能百分之百确定)。

20200210T165905+0000

我想使用powershell解析它,并尝试了以下方法

代码语言:javascript
复制
$Date = "20200210T165905+0000"
$DatePattern = "yyyyMMdd\THHmmss\+zzzz"
$DateTime = [DateTime]::ParseExact($Date, $DatePattern, $null)

但是我得到了以下错误

代码语言:javascript
复制
Exception calling "ParseExact" with "3" argument(s): "String was not recognized as a valid DateTime."

我做错了什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-02-12 11:19:29

您所拥有的数据格式需要一个不同的模式,在这种模式中,时区信息由K处理。

+0000表示日期以UTC时间为单位(偏移量为0)。如果删除它,就会像解析本地DateTime一样解析日期字符串,从而提供虚假信息(除非您生活在世界上与当地时间相同的地区)。

代码语言:javascript
复制
$Date = "20200210T165905+0000"
$DatePattern = "yyyyMMddTHHmmssK"
$DateTime = [DateTime]::ParseExact($Date, $DatePattern, $null)
$DateTime

返回(在我的NL语言环境=> UTC +1中)

10-2-2020 17:59:05

票数 2
EN

Stack Overflow用户

发布于 2020-02-12 11:00:40

\+转义字符从模式中移除似乎为我修复了它,即,

$DatePattern = "yyyyMMdd\THHmmsszzzz"

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60186646

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档