我想知道如何使用谓词过滤器过滤集合$ view。我在C#中看到了很多谓词过滤器的例子,但对PowerShell来说并不多。在PowerShell中看到一个工作示例会很棒。
基本上,当我将filter变量设置为字符串并刷新$ view时,该集合应该过滤以向我显示与过滤器匹配的行或对象。如果过滤器为空,则应显示整个对象集合。
我认为这应该可以在控制台中使用而不使用任何表单,但我无法在PowerShell中创建类型的过滤器(system.predicate)。
$a = New-Object System.Collections.ObjectModel.ObservableCollection[object]
$svcs = gsv -ComputerName LocalHost |
select @{n="Server";e={$_.machinename}},Name,Displayname,status
$svcs | ForEach {
$a.Add((
New-Object PSObject -Property @{
Server = $_.server
Name = $_.name
Displayname = $_.displayname
Status = $_.status
}
))
}
$view = [System.Windows.Data.CollectionViewSource]::GetDefaultView($a)
$filter = "bits"
$view.Filter = "Predicate FIlter???"
$view.Refresh()
答案 0 :(得分:1)
只需传递一个带有单个参数的脚本块。对于要包含在视图中的项,脚本块应返回true,对于您不想包含的项,应返回false。以下适用于PowerShell v4:
$view = [System.Windows.Data.CollectionViewSource]::GetDefaultView($a)
Write-Host "Setting filter to 'vss'"
$filter = "vss"
$view.Filter = {param ($item) $item -match $filter}
$view.Refresh()
$view
Write-Host "Setting filter to 'BITS'"
$filter = "BITS"
$view.Refresh()
$view
编辑:添加打印在我的测试计算机上的输出
在测试计算机上运行上述脚本会产生以下输出:
Setting filter to 'vss'
Status Server Name Displayname
------ ------ ---- -----------
Running LocalHost SQLWriter SQL Server VSS Writer
Stopped LocalHost vmicvss Hyper-V Volume Shado...
Stopped LocalHost VSS Volume Shadow Copy
Setting filter to 'BITS'
Running LocalHost BITS Background Intellige...