about_Type_Operators
简短说明
介绍使用 Microsoft .NET 类型的运算符。
长说明
布尔类型运算符(-is
和 -isnot
)判断对象是否是指定 .NET 类型的实例。 如果类型匹配,则 -is
运算符返回值 TRUE,否则返回值 FALSE。 如果类型匹配,则 -isnot
运算符返回值 FALSE,否则返回值 TRUE。
-as
运算符尝试将输入对象转换为指定的 .NET 类型。 如果成功,则返回转换后的对象。 如果失败,则返回 $null
。 它不返回错误。
PowerShell 有以下类型运算符:
-is
|当输入是指定 .NET 类型的实例时,返回 TRUE。(get-date) -is [DateTime] # Result is True
-isnot
|当输入不是指定 .NET 类型的实例时,返回 TRUE。(get-date) -isnot [DateTime] # Result is False
-as
|将输入转换为指定的 .NET 类型。"5/7/07" -as [DateTime] # Result is Monday, May 7, 2007 12:00:00 AM
类型运算符的语法如下:
<input> <operator> [.NET type]
还可以使用以下语法:
<input> <operator> ".NET type"
.NET 类型可以编写为类型名称(在括号中)或字符串,例如用于 System.DateTime 的 [DateTime]
或 "DateTime"
。 如果该类型不在系统命名空间的根目录,请指定对象类型的全名。 可以省略“System.”。 例如,若要指定 System.Diagnostics.Process,请输入 [System.Diagnostics.Process]
、[Diagnostics.Process]
或 "Diagnostics.Process"
。
类型运算符始终对整个输入对象进行运算。 也就是说,如果输入对象是集合,则测试的是集合类型,而不是集合的元素的类型。
-is/isnot 运算符
布尔类型运算符(-is
和 -isnot
)始终返回布尔值,即使输入是对象集合。
如果 <input>
是与 .NET 类型相同的类型或从 .NET 类型派生的类型,则 -is
运算符返回 $True
。
例如,DirectoryInfo 类型派生自 FileSystemInfo 类型。 因此,这两个示例都返回 True。
PS> (Get-Item /) -is [System.IO.DirectoryInfo]
True
PS> (Get-Item /) -is [System.IO.FileSystemInfo]
True
如果 <input>
在比较中实现了接口,则 -is
运算符也可以与接口匹配。 在此示例中,输入是一个数组。 数组实现 System.Collections.IList 接口。
PS> 1, 2 -is [System.Collections.IList]
True
-as 运算符
-as
运算符尝试将输入对象转换为指定的 .NET 类型。 如果成功,则返回转换后的对象。 如果失败,则返回 $null
。 它不返回错误。
<input>
如果该类型派生自 .NET 类型-as
,则传递返回输入对象不变。 例如,DirectoryInfo 类型派生自 FileSystemInfo 类型。 因此,在以下示例中,对象类型保持不变:
PS> $fsroot = (Get-Item /) -as [System.IO.FileSystemInfo]
PS> $fsroot.GetType().FullName
System.IO.DirectoryInfo
转换 DateTime 类型区分区域性
与类型强制转换不同,通过 -as
运算符转换为 [DateTime]
类型的操作仅适用于根据当前区域性的规则设置格式的字符串。
PS> [cultureinfo]::CurrentCulture = 'fr-FR'
PS> '13/5/20' -as [datetime]
mercredi 13 mai 2020 00:00:00
PS> '05/13/20' -as [datetime]
PS> [datetime]'05/13/20'
mercredi 13 mai 2020 00:00:00
PS> [datetime]'13/05/20'
InvalidArgument: Cannot convert value "13/05/20" to type "System.DateTime".
Error: "String '13/05/20' was not recognized as a valid DateTime."
若要查找对象的 .NET 类型,请使用 Get-Member
cmdlet。 也可将所有对象的 GetType 方法与该方法的 FullName 属性配合使用。 例如,以下语句获取 Get-Culture
命令的返回值的类型:
PS> (Get-Culture).GetType().FullName
System.Globalization.CultureInfo
示例
以下示例显示了类型运算符的一些用法:
PS> 32 -is [Float]
False
PS> 32 -is "int"
True
PS> (get-date) -is [DateTime]
True
PS> "12/31/2007" -is [DateTime]
False
PS> "12/31/2007" -is [String]
True
PS> (get-process PowerShell)[0] -is [System.Diagnostics.Process]
True
PS> (get-command get-member) -is [System.Management.Automation.CmdletInfo]
True
以下示例显示,当输入是对象集合时,匹配类型是集合的 .NET 类型,而不是集合中各个对象的类型。
在此示例中,虽然 Get-Culture
和 Get-UICulture
cmdlet 都返回 System.Globalization.CultureInfo 对象,但这些对象的集合是 System.Object 数组。
PS> (get-culture) -is [System.Globalization.CultureInfo]
True
PS> (get-uiculture) -is [System.Globalization.CultureInfo]
True
PS> (get-culture), (get-uiculture) -is [System.Globalization.CultureInfo]
False
PS> (get-culture), (get-uiculture) -is [Array]
True
PS> (get-culture), (get-uiculture) | foreach {
$_ -is [System.Globalization.CultureInfo])
}
True
True
PS> (get-culture), (get-uiculture) -is [Object]
True
下面的示例展示了如何使用 -as
运算符。
PS> "12/31/07" -is [DateTime]
False
PS> "12/31/07" -as [DateTime]
Monday, December 31, 2007 12:00:00 AM
PS> $date = "12/31/07" -as [DateTime]
C:\PS>$a -is [DateTime]
True
PS> 1031 -as [System.Globalization.CultureInfo]
LCID Name DisplayName
---- ---- -----------
1031 de-DE German (Germany)
以下示例显示,当 -as
运算符无法将输入对象转换为 .NET 类型时,它会返回 $null
。
PS> 1031 -as [System.Diagnostics.Process]
PS>