-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
82 lines (81 loc) · 1.8 KB
/
index.js
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
export function GroupBy(array, columns) {
if (!array.length || !columns.length)
return;
var array = array;
var columns = columns;
var retArr = {};
var initialize = function (type) {
if (type == 'sum' || type == 'avg') {
for (var str of columns) {
retArr[str] = 0;
}
} else if (type == 'min' || type == 'max') {
for (var str of columns) {
retArr[str] = array[0][str];
}
}
else if(type=='distinctCount'){
for (var str of columns) {
retArr[str] = {};
}
}
};
return {
sum: function () {
initialize('sum');
return array.reduce(function (a, item) {
for (var str of columns) {
retArr[str] += item[str];
}
return retArr;
}, columns);
},
min: function () {
initialize('min');
return array.reduce(function (a, item) {
for (var str of columns) {
if (item[str] < retArr[str])
retArr[str] = item[str];
}
return retArr;
}, columns);
},
max: function () {
initialize('max');
return array.reduce(function (a, item) {
for (var str of columns) {
if (item[str] > retArr[str])
retArr[str] = item[str];
}
return retArr;
}, columns);
},
avg: function () {
initialize('avg');
var retObj = array.reduce(function (a, item) {
for (var str of columns) {
retArr[str] += item[str];
}
return retArr;
}, columns);
for (var str of columns) {
retArr[str] /= array.length;
}
return retArr;
},
distinctCount: function () {
initialize('distinctCount');
var retObj = array.reduce(function (a, item) {
for (var str of columns) {
if (!retArr.hasOwnProperty(str)) retArr[str] = {};
retArr[str][item[str]] = 1;
}
return retArr;
}, columns);
for (var str of columns) {
retArr[str] = Object.keys(retArr[str]).length;
}
return retArr;
}
};
}