首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于迭代过程-exponential映射的嵌套过滤?

用于迭代过程-exponential映射的嵌套过滤?
EN

Stack Overflow用户
提问于 2019-12-28 15:22:11
回答 2查看 139关注 0票数 1

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

首先,我将根据资产价值筛选(排列)数组。

代码语言:javascript
复制
  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);

然后执行任何类型的操作,比如总结以供使用:

代码语言:javascript
复制
  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:很明显,这些数据以前是用

代码语言:javascript
复制
  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);}  
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-12-28 16:04:47

据我所知,这个问题不是指数型的。复杂性仍然是线性的,一种是简单地在扫描现有数据时添加更多的标准。

该技术是根据您要分组的字段来积累数据,以实现小计。例如,如果您想按年/月进行分组,那么所需要的只是定义小计桶的年份/月。例如,您将有一个用于“20181”、“20182”、“20183”等的桶。当您循环遍历数组中的条目时,您将使用年份/月来标识桶,并将条目值添加到小计桶中。

如果您在小计分组中包括其他字段(例如货币和年份/月),那么只需调整桶名以包括货币和年份/月。呃,你们的小桶现在是'~cad~20181~','~cad~20182~','~eur~20181~‘等等。这是按货币和年份/月来唯一标识小桶的方法。然后,与前面一样,当循环遍历数组中的条目时,您将从数组条目中获取值,以标识该值所属的货币和年份/月桶.请注意,在构造小计桶名时,倾斜符是用于分隔字段值的任意分隔符。

代码语言:javascript
复制
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循环更改代码。

代码语言:javascript
复制
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对象,但在举例说明根据小计如何分组命名小计的关键概念时,则不太清楚.

希望这能有所帮助。

票数 1
EN

Stack Overflow用户

发布于 2019-12-29 21:39:28

正如注释中所建议的那样,您可以使用一个简单的查询:

E1:

代码语言:javascript
复制
=query(A:D,"select A,B,C,sum(D) where A is not null group by A,B,C ",1)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59512167

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档