Использование команды 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]'}