powershell中的where-object

时间:2016-07-28 07:00:51

标签: powershell

我怎么能把这两个人联合起来?

Get-ItemProperty HKLM:\Software\Microsoft\Windows\CurrentVersion\Uninstall\*|`
Where-Object {$_.displayname -like "*Database Engine Services*" } |  Select-Object DisplayName, DisplayVersion, Publisher, InstallDate |Format-Table -AutoSize

Get-ItemProperty HKLM:\Software\Microsoft\Windows\CurrentVersion\Uninstall\* |  Select-Object DisplayName, DisplayVersion, Publisher, InstallDate |
Where-Object {($_.displayname -like "*Engagement*")  } |`
 Format-Table –AutoSize 

1 个答案:

答案 0 :(得分:2)

我使用RegEx方法将Where-Object过滤压缩到单个实例,但您也可以使用-OR将它带入单个实例。此外,不需要将Select-Object作为Format-Table执行,因为只需使用Format-Table就可以指定要显示的属性。

Get-ItemProperty HKLM:\Software\Microsoft\Windows\CurrentVersion\Uninstall\* | Where-Object {
    $_.DisplayName -match '^Database Engine Services|Engagement'
} | Format-Table DisplayName, DisplayVersion, Publisher, InstallDate -AutoSize

以下是使用-OR和-LIKE语句的替代方法:

Get-ItemProperty HKLM:\Software\Microsoft\Windows\CurrentVersion\Uninstall\* | Where-Object {
    $_.DisplayName -LIKE 'Database Engine Services*' -OR $_.DisplayName -LIKE '*Engagement*'
} | Format-Table DisplayName, DisplayVersion, Publisher, InstallDate -AutoSize