让我们从简单的形式开始。假设您有一个类似于此的简单数据集:您希望检索每个资产的累积金额。

首先,我将根据资产价值筛选(排列)数组。
var pairs = ["eur", "usd", "pop", "dot", "cad", "sol"];
for(i=0; i<pairs.length; i++){
var filtArray1 = dataArray.filter(function filt(el){return el.asset === pairs[i];});
filtArrays.push(filtArray1);然后执行任何类型的操作,比如总结以供使用:
var values = Object.keys(filtArrays[i]).map(function(e){return filtArrays[i][e].amount});
parziali.push(values);
var somma = values.reduce(function(acc, val) { return acc + val; }, 0);
somme.push(somma);
//result "somme": [9.0, 9.0, 6.0, 6.0, 9.0, 3.0]
}好的,您可以使用indexOf();或任何其他更快的方法,但这不是重点。
要点是:假设我们现在为这个数据集添加了一个额外的层,一些日期字段。现在我们有:

而且,与以前一样,您希望能够检索每个资产的每个周的金额(这些是一年中的周数)。
你怎么做到的?
它突然变成了exponential.您可以使用哪种类型的过程来同时保持迭代(即:自动)和轻量级工作负载?
您甚至可以在此时添加一个额外的数据层。

正如你所看到的,我们有两个不同的钱包,都持有欧元,但在同一周。
现在,我们希望能够检索的数量、的每个资产、每个周的和的、每个钱包。就像我说的,它变成了exponential:--你是如何处理它的?谢谢
ps:很明显,这些数据以前是用
for(i=0; i<data.length; i++){
var dataRow = data[i];
var record = {};
record['weeks'] = dataRow[0];
record['asset'] = dataRow[1];
record['amount'] = dataRow[2];
dataArray.push(record);} 发布于 2019-12-28 16:04:47
据我所知,这个问题不是指数型的。复杂性仍然是线性的,一种是简单地在扫描现有数据时添加更多的标准。
该技术是根据您要分组的字段来积累数据,以实现小计。例如,如果您想按年/月进行分组,那么所需要的只是定义小计桶的年份/月。例如,您将有一个用于“20181”、“20182”、“20183”等的桶。当您循环遍历数组中的条目时,您将使用年份/月来标识桶,并将条目值添加到小计桶中。
如果您在小计分组中包括其他字段(例如货币和年份/月),那么只需调整桶名以包括货币和年份/月。呃,你们的小桶现在是'~cad~20181~','~cad~20182~','~eur~20181~‘等等。这是按货币和年份/月来唯一标识小桶的方法。然后,与前面一样,当循环遍历数组中的条目时,您将从数组条目中获取值,以标识该值所属的货币和年份/月桶.请注意,在构造小计桶名时,倾斜符是用于分隔字段值的任意分隔符。
a = [
{geo:"cad", ym:20182, value:3},
{geo:"eur", ym:20181, value:1},
{geo:"pop", ym:20182, value:2},
{geo:"usd", ym:20181, value:3},
{geo:"cad", ym:20182, value:3},
{geo:"sol", ym:20181, value:1},
{geo:"cad", ym:20181, value:3},
{geo:"pop", ym:20182, value:2},
{geo:"pop", ym:20181, value:5}
];
var result = a.reduce( (totals, entry) => {
let key = '~' + entry.geo + '~' + entry.ym + '~';
totals[key] = ( totals[key] || 0 ) + entry.value;
return totals;
}, {} );
console.log( result );
使用for循环更改代码。
arr = [
{geo:"cad", ym:20182, value:3},
{geo:"eur", ym:20181, value:1},
{geo:"pop", ym:20182, value:2},
{geo:"usd", ym:20181, value:3},
{geo:"cad", ym:20182, value:3},
{geo:"sol", ym:20181, value:1},
{geo:"cad", ym:20181, value:3},
{geo:"pop", ym:20182, value:2},
{geo:"pop", ym:20181, value:5}
];
result = {};
// Loop through each entry in arr
for ( let i = 0; i < arr.length; i++ ) {
// Create the subtotal bucket name based on the fields
// defining the grouping.
let key = '~' + arr[ i ].geo + '~' + arr[ i ].ym + '~';
// Now that we know which subtotal bucket arr[i].value
// belongs, let's add it to the bucket.
result[ key ] = (result[ key ] || 0 ) + arr[ i ].value ;
}
console.log( result );
在这两个示例中,我都将值收集到一个对象中,每个属性代表一个小计桶。也可以使用Map对象,但在举例说明根据小计如何分组命名小计的关键概念时,则不太清楚.
希望这能有所帮助。
发布于 2019-12-29 21:39:28
正如注释中所建议的那样,您可以使用一个简单的查询:
E1:
=query(A:D,"select A,B,C,sum(D) where A is not null group by A,B,C ",1)https://stackoverflow.com/questions/59512167
复制相似问题