使用对象进行分组。
var categories = {};
function incrementBy(category, value) {
if (!categories[category]) {
categories[category] = 0;
}
categories[category] += value;
}
var datasetarr = [];
var pos;
for(var i = 0; i < arr.length; i++){
console.log('unsorted ' + arr[i].type + ' ' + arr[i].quantity);
incrementBy(arr[i].type, arr[i].quantity)
}
for(var category in categories){
console.log('sorted ' + category + ' ' + categories[category]);
}
如果需要,您可以分解对象,将其分解为数组并在需要时对其进行排序。
一个更简洁的例子,它可能会让你更好地理解:
var arr = [{type: 'kitchen appliance', quantity: 2},
{type: 'home entertainment', quantity: 2},
{type: 'home entertainment', quantity: 3},
{type: 'batteries & lightings', quantity: 2},
{type: 'home entertainment', quantity: 2},
{type: 'home appliance', quantity: 5},
{type: 'kitchen appliance', quantity: 4},
{type: 'kitchen appliance', quantity: 5},
{type: 'kitchen appliance', quantity: 3},
{type: 'kitchen appliance', quantity: 4},
{type: 'kitchen appliance', quantity: 1},
{type: 'home entertainment', quantity: 1},
{type: 'home appliance', quantity: 5},
{type: 'batteries & lightings', quantity: 2},
{type: 'kitchen appliance', quantity: 2},
{type: 'home appliance', quantity: 2}];
function group(array) {
var categories = {};
function incrementBy(category, value) {
if (!categories[category]) {
categories[category] = 0;
}
categories[category] += value;
}
array.forEach(function (value, index, arr) {
incrementBy(value.type, value.quantity)
});
return categories;
}
function print(categories) {
for (var category in categories) {
console.log('%s: %s', category, categories[category]);
}
}
print(group(arr));
这里是group 隐藏分组的解决方案,它可以容纳您自己的实现:
function group(array) {
var categories = {};
function incrementBy(object) {
var category = categories[object.type];
if (!category) {
category = categories[object.type] = {};
}
var subCategory = category[object.subType];
if (!subCategory) {
subCategory = category[object.subType] = {};
}
subCategory += object.value;
}
array.forEach(function (value, index, arr) {
incrementBy(value, value.quantity)
});
return categories;
}
根据您的用例,您还可以展平结构:
function incrementBy(object) {
var key = [object.type, object.subType].join('/');
var category = categories[key];
if (!category) {
category = categories[key] = {};
}
subCategory += object.value;
}
但是有不同的地图可能是有意义的:
function groupings(array) {
var groupings = {
types: {},
subTypes: {},
paths: {}
};
function incrementBy(object) {
var category = groupings['types'][object.type];
if (!category) {
category = groupings['types'][object.type] = {};
}
category += object.value;
var subCategory = groupings['subTypes'][object.subType];
if (!subCategory) {
subCategory = groupings['subTypes'][object.subType] = {};
}
subCategory += object.value;
var key = [object.type, object.subType].join('/');
var path = groupings['paths'][key];
if (!path) {
path = groupings['paths'][key] = {};
}
path += object.value;
}
array.forEach(function (value, index, arr) {
incrementBy(value, value.quantity)
});
return categories;
}
为避免聚合信息丢失,您可以简单地创建一个更复杂的数据结构:
function groupByAndSumBy(data, groupByProperty, sumByProperty) {
var accumulator = {};
data.forEach(function(object, index, array) {
var localAcc = accumulator[groupByProperty]
= accumulator[groupByProperty] || { items: [] };
localAcc[sumByProperty]
= (localAcc[sumByProperty] || 0) + object[sumByProperty];
localAcc.items.push(object);
});
return accumulator;
}
function groupByMerchantNameAndSumByTotalSales(data) {
return groupByAndSumBy(data, 'merchantName', 'totalSales');
}
这将创建一个聚合,其中还包含输入数组的子集,从而可以更详细地查看数据。