-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathConvert-ObjectToHashtable.ps1
47 lines (43 loc) · 1.51 KB
/
Convert-ObjectToHashtable.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
function Convert-ObjectToHashtable {
<#
.SYNOPSIS
Takes a single object and converts its properties and values into a hashtable.
.DESCRIPTION
Takes a single object and converts its properties and values into a hashtable.
.PARAMETER Object
The Object to turn into a hashtable
.PARAMETER ExcludeEmpty
Switch to exclude empty properties
.EXAMPLE
Convert-ObjectToHashtable -object Value -ExcludeEmpty
.NOTES
Source: https://community.idera.com/database-tools/powershell/powertips/b/tips/posts/turning-objects-into-hash-tables-2
# todo - need better example
#>
#region parameter
[CmdletBinding(ConfirmImpact='Low')]
[OutputType([hashtable[]])]
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSReviewUnusedParameter','')]
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments','')]
param
(
[Parameter(Mandatory,ValueFromPipeline)]
[psobject] $object,
[Switch]
$ExcludeEmpty
)
#endregion parameter
process {
$object.PSObject.Properties |
# sort property names
Sort-Object -Property Name |
# exclude empty properties if requested
Where-Object { ($ExcludeEmpty.IsPresent -eq $false) -or ($null -ne $_.Value) } |
ForEach-Object -begin {
$hashtable = ([Ordered]@{}) } -process {
$hashtable[$_.Name] = $_.Value
} -end {
Write-Output -InputObject $hashtable
}
}
}