15

我正在使用 PowerShell SQLite模块解析 SQLite 数据库,并创建和修改了几个返回值,这两个值都是 Unix 时间的。

我想做的是以某种方式将其转换为“人类时间”。为了便于阅读,我删除了一些其他 SQL 查询。

Import-Module SQLite
mount-sqlite -name GoogleDrive -dataSource E:\Programming\new.db
$cloud_entry = Get-ChildItem GoogleDrive:\cloud_entry

foreach ($entry in $cloud_entry)
{
    $entry.created
}

输出看起来像一大列 Unix 时间戳:

1337329458

更新:我最终选择了以下内容:

$ctime = $entry.created
[datetime]$origin = '1970-01-01 00:00:00'
$origin.AddSeconds($ctime)
4

9 回答 9

30

请参阅将 Unix 时间戳转换为 .NET DateTime

您可以在 PowerShell 中轻松重现这一点。

$origin = New-Object -Type DateTime -ArgumentList 1970, 1, 1, 0, 0, 0, 0
$whatIWant = $origin.AddSeconds($unixTime)
于 2012-05-28T08:45:27.547 回答
19
Function Convert-FromUnixDate ($UnixDate) {
   [timezone]::CurrentTimeZone.ToLocalTime(([datetime]'1/1/1970').AddSeconds($UnixDate))
}

$niceTime = Convert-FromUnixDate $ctime

PS C:\> $niceTime

Friday, 18 May 2012 8:24:18 p.m.
于 2014-01-20T13:00:41.940 回答
12

采用:

(([System.DateTimeOffset]::FromUnixTimeSeconds($unixTime)).DateTime).ToString("s")

FromUnixTimeMilliseconds也可用。

ToString("s"): Sortable: "模式反映了定义的标准 (ISO 8601)"

参考:标准日期和时间格式字符串,可排序(“s”)格式说明符

于 2018-11-06T16:26:49.637 回答
8
$date = get-date "1/1/1970"
$date.AddSeconds($unixTime).ToLocalTime()
于 2016-03-22T11:39:50.797 回答
5

一个简单的单行:

(Get-Date "1970-01-01 00:00:00.000Z") + ([TimeSpan]::FromSeconds($unixTime))
于 2018-01-15T14:32:48.860 回答
2

没有带来任何新东西,而是 Fredrics 的一个 pipable 版本的回答:

function epoch() { 
    Param( 
        [Parameter(ValueFromPipeline)]$epochTime,
        [Switch]$Ms
    ) 
    Process { 
        if ($Ms) {
            [System.DateTimeOffset]::FromUnixTimeMilliseconds($epochTime)
        } else {
            [System.DateTimeOffset]::FromUnixTimeSeconds($epochTime)
        }
    } 
}
"1628043561861" | epoch -Ms

DateTime      : 04.08.2021 02:19:21
UtcDateTime   : 04.08.2021 02:19:21
LocalDateTime : 04.08.2021 04:19:21
Date          : 04.08.2021 00:00:00
Day           : 4
DayOfWeek     : Wednesday
DayOfYear     : 216
Hour          : 2
Millisecond   : 861
Minute        : 19
Month         : 8
Offset        : 00:00:00
Second        : 21
Ticks         : 637636403618610000
UtcTicks      : 637636403618610000
TimeOfDay     : 02:19:21.8610000
Year          : 2021
于 2021-08-04T06:19:01.510 回答
1
$ctime = $entry.created
[datetime]$origin = '1970-01-01 00:00:00'
$origin.AddSeconds($ctime)
于 2012-05-28T09:02:31.417 回答
1

我想确定我是从 UTC 计算的,所以我添加了SpecifyKind

$epochStart = New-Object -Type DateTime -ArgumentList 1970, 1, 1, 0, 0, 0, 0
$epochStart = [DateTime]::SpecifyKind($epochStart,[DateTimeKind]::Utc)

$DateTimeUTC = $epochStart.AddSeconds($UnixTimestamp)
于 2020-04-21T11:06:52.093 回答
1

我发现建议的解决方案都没有解决我的需求。所以我调整并提出以下建议:

function ConvertFrom-UnixTime {
    [CmdletBinding(DefaultParameterSetName = "Seconds")]
    param (
        [Parameter(Position = 0, 
            ValueFromPipeline = $true, 
            Mandatory = $true,
            ParameterSetName = "Seconds")]
        [int]
        $Seconds,

        [Parameter(Position = 0, 
            ValueFromPipeline = $true, 
            Mandatory = $true, ParameterSetName = "Miliseconds")]
        [bigint]
        $Miliseconds
    )
    Begin {
        $date = (Get-Date "1970-01-01 00:00:00.000Z")
    }
    Process {
        switch ($PSCmdlet.ParameterSetName) {
            "Miliseconds" {
                $date = $date.AddMilliseconds($Miliseconds)
            }
            Default {
                $date = $date.AddSeconds($Seconds);
            }
        }
    }
    End {
        $date
    }
}
Set-Alias -Name epoch -Value ConvertFrom-UnixTime

用法:

1633694244| epoch
1633694244565 | epoch

两个输出:

8. oktober 2021 12:57:24
于 2021-10-08T13:18:11.610 回答