如何使用Windows PowerShell脚本计算今天1601-01-01以来的毫秒数? 我需要这个来构建正确的LDAP查询。
答案 0 :(得分:5)
DateTime
结构包含方法ToFileTime
。根据{{3}},
Windows文件时间是一个64位值,表示数量 自午夜12:00起经过的100纳秒间隔, 1601年1月1日A.D.(C.E。)世界协调时间(UTC)。
因此,从ns(10e-9)到ms(10e-3)是简单的算术。请记住,计数器计数100 ns块,而不是1 ns块。该值存储为Int64,因此不需要进行类型转换。像这样,
PS C:\> (Get-Date).ToFileTime()
130142949169114886
PS C:\> (Get-Date).ToFileTime().GetType()
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True True Int64 System.ValueType
答案 1 :(得分:1)
完全同意@vonPryz的回答。只是为了好玩你可以在Powershell tick
的{{1}}属性中找到100纳秒的数量。但是这个勾号不是来自“01/01/1600”而是来自([datetime] :: MinValue)“01/01/0001”。
尝试:
System.DateTime
答案 2 :(得分:0)
这是正确的:
(Get-Date).ToFileTime()/10000
即使上面的简单解决方案(Get-Date).ToFileTime()给出10,000次错误,甚至都想到会发生什么事,这真是令人恐惧。
4205233年。太可怕了
$a = ([datetime]::Now).Ticks
$secTimer=1
Start-Sleep -Seconds $secTimer
$b = ([datetime]::Now).Ticks
$c=$b-$a
'ticks={0} == {1} sec and {2} ticks' -f $c,[int](Get-Date $c -Format "ss"),[int](Get-Date $c -Format "fffffff")
$TicksPerSec = $c/$secTimer
'ticks per second = {0}' -f ($c/$secTimer)
echo "`n"
$Year=1601;$Month=1;$date=1;$hour=0;$minutes=0;$Seconds=0;$mSeconds=0;
$Ticks1601 = New-Object DateTime $Year, $Month, $date, $hour, $minutes, $Seconds, $mSeconds
'Ticks on Jan 1 1601 00:00:00 = {0}' -f $Ticks1601.Ticks
$TicksNow = ([datetime]::Now).Ticks
$time=$TicksNow-$Ticks1601
'after Jan 1 1601 00:00:00'
' milliseconds {0}' -f ($time.Ticks/$TicksPerSec*1000)
$seconds=$time.Ticks/$TicksPerSec
' seconds = {0}' -f $seconds
$min=$seconds/60
' minutes = {0}' -f $min
$hours=$min/60
' hours = {0}' -f $hours
$days=$hours/24
' days = {0}' -f $days
$years=$days/364.75
' years = {0}' -f $years
echo "`nand`n"
$ms=(Get-Date).ToFileTime()
'simple ToFileTime() after Jan 1 1601 00:00:00'
' milliseconds {0}' -f $ms
$years=$ms/1000/60/60/24/364.75
' years = {0}' -f $years
'???'
echo "`n"
$Year=1;$Month=1;$date=1;$hour=0;$minutes=0;$Seconds=0;$mSeconds=0;
$time = New-Object DateTime $Year, $Month, $date, $hour, $minutes, $Seconds, $mSeconds
'Ticks on Jan 1 0001 00:00:00 = {0}' -f $time.Ticks