Invoke-Sum.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
function Invoke-Sum {
    param(
        $data,
        $dimension,
        $measure
    )

    if(!$measure) {$measure = $dimension}

    $h=@{}

    foreach ($item in $data){
        $key=$item.$dimension

        if(!$key) {$key="[missing]"}

        if(!$h.ContainsKey($key)) {
            $h.$key=[ordered]@{}
        }

        foreach($m in $measure) {        
            $value = $item.$m
            if($value -is [string] -or $value -is [System.Enum]) {
                $value = 1
            }

            $h.$key.$m+=$value
        }
    }
    
    foreach ($entry in $h.GetEnumerator()){
        
        $nh=[ordered]@{Name=$entry.key}
        
        foreach ($item in $entry.value.getenumerator()) {
            $nh.($item.key)=$item.value
        }        
        
        [pscustomobject]$nh
    }
}