Functions/Test-IsNumeric.ps1
Function Test-IsNumeric { <# .SYNOPSIS Determines if specified string can be parsed to a number .DESCRIPTION Determines if specified string can be parsed to a number. Can specify a string, an array of strings, or input from the pipeline .PARAMETER NumString A string or string array to test to determine if they are numeric. Aliased as 'Number' .PARAMETER IncludeInput Switch to include the input parameters in the output .EXAMPLE Test-IsNumeric '1.2' True .EXAMPLE Test-IsCapsLock -Verbose #> [CmdletBinding(ConfirmImpact='None')] [OutputType('bool')] Param ( [parameter(ValueFromPipeLine,ValueFromPipeLineByPropertyName)] [Alias('Number')] [string[]] $NumString, [switch] $IncludeInput ) begin { Write-Verbose -Message "Starting [$($MyInvocation.Mycommand)]" } process { foreach ($n in $NumString) { $n = $n.Trim() if (($n -eq '') -or ($null -eq $n)) { if ($IncludeInput) { New-Object -TypeName psobject -Property ([ordered] @{Input="$n";Result=$false}) } else { Write-Output -InputObject $false } } else { try { 0 + $n | Out-Null if ($IncludeInput) { New-Object -TypeName psobject -Property ([ordered] @{Input="$n";Result=$true}) } else { Write-Output -InputObject $true } } catch { if ($IncludeInput) { New-Object -TypeName psobject -Property ([ordered] @{Input="$n";Result=$false}) } else { Write-Output -InputObject $false } } } } } end { Write-Verbose -Message "Ending [$($MyInvocation.Mycommand)]" } } #EndFunction Test-IsNumeric |