3

我有这个数组(简化):

$v = 3,5,3,6,8,3,5,7

我需要检查所有值是否都高于 3。我认为 Foreach 或 Foreach-Object 将适合此任务,但我无法弄清楚它的工作方式。

我已经尝试过这样的事情,但它不起作用。

$v | Foreach-Object (if($_ -lt 10){Write-Host "$_ lt 10"})

编辑:

感谢你们!我将声明更改为:

$v | Foreach-Object {if($_ -lt 10){$check_value = "True"}}

它现在可以工作了,但我刚刚意识到,简单化的数组不是一个好主意。我正在使用的数组中的数据是从 MS SQL 数据库中获取的。如果我在屏幕上显示数组,我会得到数字,但数据类型是 System.Data.DataRow,我无法与数字进行比较。我收到错误消息:

Bad argument to operator '-lt': Could not compare "System.Data.DataRow" to "95". Error: "Cannot convert the "95" value of type "System.Int32" to type "System.Data.DataRow".".

编辑2:

飞溅的比特:

我正在使用您的代码,一切正常,但我无法通过此比较:

$rowsGreaterThanThree.Count -eq $v.Count

$rowsGreaterThanThree 的值是:

处理器时间

0.00127998361620918
1.53972183002211
0.00127998361620918
0.00127998361620918
0.00127998361620918
1.53972183002211
0.00127998361620918
0.00127998361620918
0.00127998361620918
3.1262399841282
0
0
0
0
0

和 $v 包含:

处理器时间

0.00127998361620918
1.53972183002211
0.00127998361620918
0.00127998361620918
0.00127998361620918
1.53972183002211
0.00127998361620918
0.00127998361620918
0.00127998361620918
3.1262399841282
0
0
0
0
0

值是相同的,但在“ProcessorTime”下方的 $v 中还有一个空白行(此处不可见)。Count 在 $rowsGreaterThanThree.Count 中给出 16 而不是 15。

我的代码:(我将 -gt 修改为 -ge,因为有零。在工作版本中,我想检查处理器是否在一段时间内加载到 95% 以上。)

$warning_values = @( $check | Where-Object { $_.ProcessorTime -ge 0 } )
if($warning_values.Count -eq $check.Count )
    {
        Write-Host -ForegroundColor "Warning!"
        }
        else { Write-Host "nothing"}
4

2 回答 2

5

简单的 :)

PS> $v -gt 3
5
6
8
5
7

或者

$v | Where-Object { $_ -gt 3 }
于 2012-09-11T13:17:20.077 回答
2

Shay 的示例非常完美:用于Where-Object过滤数组中的项目。

因为您的对象是DataRow对象,所以您需要对列进行过滤:

$rowsGreaterThanThree = @( $v | Where-Object { $_.ColumnName -gt 3 } )
if( $rowsGreaterThanThree.Count -eq $v.Count )
{
  Write-Host "All the rows are greater than 3!"
}

替换ColumnName为包含要过滤的实际值的列的名称。

您也可以在 SQL 中使用WHERE子句执行此操作:

SELECT * FROM Table WHERE Column > 3

然后,您就可以从 SQL Server 中获得所需的值。当然,您可能还需要脚本中未过滤的值。

于 2012-09-11T15:48:47.433 回答