powershell - 如何选择数组属性匹配变量的对象?

标签 powershell object match pipeline

我正在尝试从具有与“蓝色”匹配的属性颜色的对象数组中选择一个对象输出数组,因为 -match 运算符在将整个对象数组与属性匹配时存在性能问题(大列表上 1-2 秒)

伪代码:

$ObjectArray.Count => 999999 
$ObjectArray.Color = "Red"
$ObjectArray[2342] = "Blue"

<#
$result = $ObjectArray -match "Blue"  # Takes too Long

return $result
#>

# What I Need:
$result = Get-Object $Object from ObjectArray | where  
($ObjectArray.color -match "Blue")  # how to?

return $result

预期结果:

$result
>> 
ID    : 2343
Color : Blue

$ObjectArray[0]
>>
ID    : 1
Color : Red

最佳答案

假设您只想要第一个匹配项,这就是给我最快的搜索结果的原因:

$result = foreach ($obj in $objectarray) {
    if ($obj.color -eq "blue") {
        $obj
        break
    }
}

在我有限的发现中,-eq 似乎是一个比 -match 更快的运算符。仅返回第一个 匹配项的技术可能会有很大差异,具体取决于匹配项在数组中的位置。索引 3 处的匹配返回速度明显快于索引 999999 处的匹配。

下面的所有测试都是在一个包含一百万个项目的数组上完成的。

测试用例 1:对整个对象使用 -match

Measure-Command {
 $result = $objectarray -match "blue"
 $result
 }


Days              : 0
Hours             : 0
Minutes           : 2
Seconds           : 3
Milliseconds      : 799
Ticks             : 1237994203
TotalDays         : 0.00143286366087963
TotalHours        : 0.0343887278611111
TotalMinutes      : 2.06332367166667
TotalSeconds      : 123.7994203
TotalMilliseconds : 123799.4203

测试用例 2:使用带有默认模式和运算符 -eqwhere() 方法

Measure-Command {
 $result = $objectarray.where{$_.color -eq "blue"}
 }


Days              : 0
Hours             : 0
Minutes           : 1
Seconds           : 8
Milliseconds      : 823
Ticks             : 688235093
TotalDays         : 0.000796568394675926
TotalHours        : 0.0191176414722222
TotalMinutes      : 1.14705848833333
TotalSeconds      : 68.8235093
TotalMilliseconds : 68823.5093

测试用例 3:使用 Where() 方法和 First 模式

Measure-Command {
 $result = $objectarray.where({$_.color -eq "blue"},'First')
 }


Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 12
Ticks             : 128258
TotalDays         : 1.48446759259259E-07
TotalHours        : 3.56272222222222E-06
TotalMinutes      : 0.000213763333333333
TotalSeconds      : 0.0128258
TotalMilliseconds : 12.8258

测试用例 4:使用 foreachbreak 语句

measure-command {
     $result = foreach ($obj in $objectarray) {
         if ($obj.color -eq "blue") {
             $obj
             break
         }
     }
 }


Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 7
Ticks             : 74482
TotalDays         : 8.62060185185185E-08
TotalHours        : 2.06894444444444E-06
TotalMinutes      : 0.000124136666666667
TotalSeconds      : 0.0074482
TotalMilliseconds : 7.4482

测试用例 5:使用 where() 方法和 -match 运算符

Measure-Command {
  $result = $objectarray.where{$_.color -match "^blue"}
  }


Days              : 0
Hours             : 0
Minutes           : 1
Seconds           : 25
Milliseconds      : 58
Ticks             : 850588447
TotalDays         : 0.000984477369212963
TotalHours        : 0.0236274568611111
TotalMinutes      : 1.41764741166667
TotalSeconds      : 85.0588447
TotalMilliseconds : 85058.8447

测试用例 6:管道传输到 Where-Object

Measure-Command {
  $result = $objectarray | where-object {$_.color -eq "blue"}
  }


Days              : 0
Hours             : 0
Minutes           : 2
Seconds           : 50
Milliseconds      : 478
Ticks             : 1704782030
TotalDays         : 0.00197312734953704
TotalHours        : 0.0473550563888889
TotalMinutes      : 2.84130338333333
TotalSeconds      : 170.478203
TotalMilliseconds : 170478.203

关于powershell - 如何选择数组属性匹配变量的对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57304184/

相关文章:

powershell - Get-ADGroup 返回与 dsquery 不同的 ObjectGUID

powershell - 相当于 Powershell 中的 `type -a`

c# - Powershell哈希表作为C#中自定义cmdlet的参数

arrays - 连接两个具有相同键的 json 对象

c++ - OpenCV undefined reference 库中我自己的方法

powershell - Azure管道:基于OS的条件环境变量

powershell - 如何根据 powershell 中对象的两个属性选择唯一对象?

sql - 在两个表之间使用 MAX 聚合

string - 比较行并从匹配中创建新行

javascript - 为什么 string.match(...)[0] 会抛出异常?