Использование команды Powershell "where" для сравнения с массивом значений
Я пытаюсь найти способ заставить эту команду фильтровать из массива значений, а не из одного значения. В настоящее время это мой код (и он работает, когда $ExcludeVerA-одно значение):
$ExcludeVerA = "7"
$java = Get-WmiObject -Class win32_product | where { $_.Name -like "*Java*"} |
where ({ $_.Version -notlike "$ExcludeVerA*" })
и я хотел бы, чтобы $ExcludeVerA имел массив таких значений (в настоящее время это не работает):
$ExcludeVerA = "7", "3", "4"
foreach ($x in $ExcludeVerA)
{
$java = Get-WmiObject -Class win32_product | where { $_.Name -like "*Java*"} |
where ({ $_.Version -notlike "$ExcludeVerA*" })
}
любые идеи о том, почему этот второй блок кода не работает или другие идеи о том, что я могу сделать?
2 ответов
попробовать -notcontains
where ({ $ExcludeVerA -notcontains $_.Version })
Итак, если я правильно понимаю, то
$ExcludeVerA = "7", "3", "4"
$java = Get-WmiObject -Class win32_product | where { $_.Name -like "*Java*"} |
where ({ $ExcludeVerA -notcontains $_.Version })
Это был прямой ответ на ваш вопрос. Возможным решением может быть что-то вроде этого:
$ExcludeVerA = "^(7|3|4)\."
$java = Get-WmiObject -Class win32_product |
where { $_.Name -like "*Java*"} |
where { $_.Version -notmatch $ExcludeVerA}
он использует регулярное выражение, чтобы получить работу.
попробуйте это:
Get-WmiObject -Class Win32_Product -Filter "Name LIKE '%Java%'" |
Where-Object {$_.Version -notmatch '[734]'}