Home > Net >  Array Row index function
Array Row index function

Time:01-06

I created a function to find an item in an array so I can update it.

  function Get-ArrayRowIndex {
                param(
                    [parameter(mandatory = $true)][array]$Property,
                    [parameter(mandatory = $true)][string]$Value
                )
           
                #Loop through array,incrementing index until value is found. Jordan wrote this and I refined it.
                [int]$index = 0
                while ($index -lt ($Property.count)) {
                    if ($Property[$index] -eq $Value) {
                        break
                    }
                    $index  
                }
                return [int]$index
            }

The problem is when the object is not found the function returns the total number of items in the array. How can I return an error if not found?

CodePudding user response:

If you want to throw an error in case the value isn't found:

function Get-ArrayRowIndex {
                param(
                    [parameter(mandatory = $true)][array]$Property,
                    [parameter(mandatory = $true)][string]$Value
                )
           
                [int]$index = 0
                while ($index -lt ($Property.count)) {
                    if ($Property[$index] -eq $Value) {
                        # Found -> output the value and return (exit) here.
                        return $index 
                    }
                    $index  
                }
                # Getting here means that the value wasn't found.
                throw "'$Value' not found in the given array."
            }

Note that you could use the [Array]::FindIndex() method instead of looping through the array yourself:

# Returns the index if found; -1 otherwise.
[Array]::FindIndex(
  $Property, 
  [Predicate[object]] { $Value -eq $args[0] }
)

[Array].IndexOf() is another option, but only if case-sensitive string comparison is desired (whereas PowerShell's operators, such as -eq used above, are case-insensitive by default); e.g., ('FOO', 'bar').IndexOf('foo') yields -1 (not found) and ('FOO', 'foo').IndexOf('foo') yields 1

CodePudding user response:

Normally a for loop is a cleaner approach for this:

function Get-ArrayRowIndex {
    param(
        [parameter(mandatory = $true)][array]$Property,
        [parameter(mandatory = $true)][string]$Value
    )

    for($i = 0; $i -lt $Property.Count; $i  )
    {
        if($Property[$i] -eq $Value)
        {
            return $i
        }
    }
    
    throw "$Value not found in this array."
}

$arr = 0..10
Get-ArrayRowIndex $arr 4  # => returns 4
Get-ArrayRowIndex $arr 11 # => throws "11 not found in this array."
  •  Tags:  
  • Related