我正在尝试创建一个while循环,如果在另一个数组中找到准确的字符串匹配,则它的条件块将导致true或false。如果找到精确匹配,则应该迭代到数组中的下一项,直到条件为false为止。
$Name = "a", "b", "c", "d", "e", "f", "g", "h", "i", "j"
$row = "j"
$i = 0
While($row | Where-Object {$_ -match $Name[$i]}){$i++}所需的输出将是$i = 9,因为它必须遍历$Name数组中的所有字符串到第9个字符串。
发布于 2018-09-26 03:09:20
您可以使用[Array]::IndexOf()而不是循环:
$Name = "a", "b", "c", "d", "e", "f", "g", "h", "i", "j"
$row = "j"
$i = [Array]::IndexOf($Name, $row) # -> $i equals 9如果没有找到匹配项,$i将包含-1。
至于你的尝试:
-ceq ( -eq运算符的区分大小写的形式),而不是-match,因为-match用于基于正则表达式的匹配(没有锚查找子字符串匹配)。如果您想用PowerShell循环来解决这个问题,我建议使用一个简单的for循环:
for ($i=0; $i -lt $Name.Count; ++$i) { if ($row -ceq $Name[$i]) { break } }在这种情况下,如果没有找到匹配,$i将包含$Name.Count的值。
https://stackoverflow.com/questions/52509337
复制相似问题