New-TimeSpan
创建 TimeSpan 对象。
语法
New-TimeSpan
[[-Start] <DateTime>]
[[-End] <DateTime>]
[<CommonParameters>]
New-TimeSpan
[-Days <Int32>]
[-Hours <Int32>]
[-Minutes <Int32>]
[-Seconds <Int32>]
[-Milliseconds <Int32>]
[<CommonParameters>]
说明
New-TimeSpan
cmdlet 创建表示时间间隔的 TimeSpan 对象。
可以使用 TimeSpan 对象在 DateTime 对象中加减时间。
不使用参数时,New-TimeSpan
命令返回表示时间间隔零的一个 TimeSpan 对象。
示例
示例 1:创建指定持续时间的 TimeSpan 对象
此命令创建一个持续时间为 1 小时 25 分钟的 TimeSpan 对象,并将其存储在名为 $TimeSpan
的变量中。 它将显示 TimeSpan 对象的表示形式。
$TimeSpan = New-TimeSpan -Hours 1 -Minutes 25
$TimeSpan
Days : 0
Hours : 1
Minutes : 25
Seconds : 0
Milliseconds : 0
Ticks : 51000000000
TotalDays : 0.0590277777777778
TotalHours : 1.41666666666667
TotalMinutes : 85
TotalSeconds : 5100
TotalMilliseconds : 5100000
示例 2:创建时间间隔的 TimeSpan 对象
此示例将创建一个新的 TimeSpan 对象,用于表示从运行该命令到 2010 年 1 月 1 日之间的时间间隔。
此命令不需要 Start 参数,因为 Start 参数的默认值为当前日期和时间。
New-TimeSpan -End (Get-Date -Year 2010 -Month 1 -Day 1)
示例 3:获取从当前日期起 90 天的日期
$90days = New-TimeSpan -Days 90
(Get-Date) + $90days
这些命令将返回当前日期之后的 90 天的日期。
示例 4:发现自更新文件以后的 TimeSpan
此命令告知你自最后一次更新 about_remote 帮助文件后经过了多长时间。 可以对任何文件或具有 LastWriteTime 属性的任何其他对象使用此命令格式。
此命令有效,因为 New-TimeSpan
的 Start 参数具有别名 LastWriteTime。 当你通过管道将具有 LastWriteTime 属性的对象传递给 New-TimeSpan
时,PowerShell 会将 LastWriteTime 属性的值用作 Start 参数的值。
Get-ChildItem $PSHOME\en-us\about_remote.help.txt | New-TimeSpan
Days : 321
Hours : 21
Minutes : 59
Seconds : 22
Milliseconds : 312
Ticks : 278135623127728
TotalDays : 321.916230471907
TotalHours : 7725.98953132578
TotalMinutes : 463559.371879547
TotalSeconds : 27813562.3127728
TotalMilliseconds : 27813562312.7728
参数
-Days
指定时间跨度(以天为单位)。 默认值为 0。
类型: | Int32 |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-End
指定时间跨度的结束时间。 默认值为当前日期和时间。
类型: | DateTime |
Position: | 1 |
默认值: | Current date and time |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-Hours
指定时间跨度(以小时为单位)。 默认值为 0。
类型: | Int32 |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-Milliseconds
指定时间跨度的长度(以毫秒为单位)。 默认值为 0。
类型: | Int32 |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-Minutes
指定时间跨度(以分钟为单位)。 默认值为 0。
类型: | Int32 |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-Seconds
指定时间跨度的长度(以秒为单位)。 默认值为 0。
类型: | Int32 |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-Start
指定时间跨度的开始时间。 输入一个表示日期和时间的字符串(例如“3/15/09”)或 DateTime 对象(例如 Get-Date
命令返回的一个对象)。 默认值为当前日期和时间。
可以使用 Start 或其别名 LastWriteTime。 借助 LastWriteTime 别名,可以通过管道将具有 LastWriteTime 属性的对象(例如文件系统 [System.Io.FileIO]
中的文件)传递给 New-TimeSpan
的 Start 参数。
类型: | DateTime |
别名: | LastWriteTime |
Position: | 0 |
默认值: | Current date and time |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
输入
可以通过管道将表示开始时间的 DateTime 对象传递给此 cmdlet。
输出
此 cmdlet 返回一个表示时间范围的对象。