Functions/Measure-Char.ps1
function Measure-Char { <# .SYNOPSIS To count the number of times a character appears in a string, or an array of strings. .DESCRIPTION To count the number of times a character appears in a string, or an array of strings. By default the function is case sensitive, but can be controlled with the $IgnoreCase switch. Can also optionally include the command line parameters passed to the program with the $IncludeInput switch .PARAMETER String A string, or an array of strings to count character against. Can accept pipeline input. .PARAMETER Char The individual character that you wish to count occurrences of. .PARAMETER IgnoreCase By default this function is case sensitive and this switch makes the function case insensitive. .PARAMETER IncludeInput A switch to display the parameters specified when the function was called and the resulting count. Aliased to 'IncludeOriginal' .EXAMPLE Measure-Char -String 'Password' -Char 'S' -IgnoreCase -IncludeInput Would return String Char IgnoreCase Count ------ ---- ---------- ----- Password S True 2 .EXAMPLE Measure-Char -String 'Password' -Char 'S' Would return 0 as the function by default is case sensitive. #> # todo Change += to System.Collections.Arraylist [cmdletbinding()] param( [parameter(Mandatory, HelpMessage='Enter the string you wish to search for a particular character', ValueFromPipeline, Position = 0)] [string[]] $String, [parameter(Mandatory, HelpMessage='The character you want to search for', Position = 1)] [char] $Char, [switch] $IgnoreCase, [Alias('IncludeOriginal')] [switch] $IncludeInput ) begin { Write-Verbose -Message "Starting [$($MyInvocation.Mycommand)]" [char[]] $CharArray = @() [string] $DisplayString = '' } process { foreach ($CurrentString in $String) { $CharArray += ([char[]] $CurrentString) if ($DisplayString -eq '') { $DisplayString = $CurrentString } else { $DisplayString = @($DisplayString, $CurrentString) -join ' ' } } } end { if ($IgnoreCase) { $ReturnValue = ($CharArray | Where-Object { $_ -match $Char } | Measure-Object ).count } else { $ReturnValue = ($CharArray | Where-Object { $_ -cmatch $Char } | Measure-Object ).count } if ($IncludeInput) { New-Object -TypeName 'pscustomobject' -Property ([ordered] @{ String = $DisplayString Char = $Char IgnoreCase = $IgnoreCase Count = $ReturnValue }) } else { Write-Output -InputObject $ReturnValue } Write-Verbose -Message "Ending [$($MyInvocation.Mycommand)]" } } |