1 powershell timezone datetime date utc
我有日期时间字符串进来,格式如下:
2017-08-03T12:30:00.000Z
我需要能够将这些转换为 EST。我尝试过的每个函数都会抛出一个或另一个错误,通常是:
"String was not recognized as a valid DateTime."
我尝试了以下变体:
$time = '2017-08-03T12:30:00.000Z'
[datetime]$datetime = $time
$culture = [Globalization.CultureInfo]::InvariantCulture
[DateTime]::ParseExact($datetime, 'MM-dd-yyyy HH:mm:ss', $culture)
Run Code Online (Sandbox Code Playgroud)
我认为这与我引用的日期时间字符串如何具有**T**UTC 时间有关,但不知道该怎么做。也许我应该解析时间,转换它,然后重新附加到字符串的第一部分,日期,并将它们组合在一起以获得最终输出?似乎工作量太大,而解决方案可能会在将来导致潜在错误。
您应该能够通过DateTime简单地将 Zulu 时间字符串转换为一个值。但是,结果值将采用本地时间,因此您应该将其转换回 UTC 以进行进一步计算:
$timestamp = '2017-08-03T12:30:00.000Z'
$datetime = ([DateTime]$timestamp).ToUniversalTime()
Run Code Online (Sandbox Code Playgroud)
然后您可以使用TimeZoneInfo该类将 UTC 时间戳转换为所需的时区:
[TimeZoneInfo]::ConvertTimeBySystemTimeZoneId($datetime, 'Eastern Standard Time')
Run Code Online (Sandbox Code Playgroud)
使用[TimeZoneInfo]::GetSystemTimeZones() | Select-Object Id, DisplayName得到认可时区列表。