JavaScript随手笔记---数组中相同的元素进行分组(数据聚合) groupBy函数

简介: JavaScript随手笔记---数组中相同的元素进行分组(数据聚合) groupBy函数



一、数据聚合

1.groupBy()函数

  聚合用groupBy这个函数,它传两个形参一为对象数组,二为匿名函数(该函数功能:返回对象的某个指定属性的属性值并存放在数组中)

groupBy: function(array, func){
    var groups = {};
    array.forEach(function(element){
      var group = JSON.stringify(func(element));
      groups[group] = groups[group] || []; //第一次执行为空数组
      //groups[group] = [] //这样写就会覆盖之前的数据,视情况而用
      groups[group].push([element,group]);//这里可以单独传element,本人是需要用到group才需要进行push
    });
    return Object.keys(groups).map(function(group){
      return groups[group];
    });
  },

  这里返回的是数组,需要返回key所对应的数组可以

return Object.keys(groups).map(function(group){
      return groups[group];
    });

  Object.keys(groups)是取出groups对象中的所有key,然后遍历一个个key组成的新数组,返回分好了组的二维数组

  • .groupBy函数内,先创建一个空对象;
  • 然后forEach遍历对象数组,遍历时要执行的函数中只有一个形参element(数组中的每个元素);
  • 由于下面函数调用是想用name来分组,因此let group = JSON.stringify( func(element) ),相当于先获取到数组中的想要用来排序的属性(这里我用返回的new Date(item.timestamp * 1000).getHours(),就是时间戳转换出的小时)对应的属性值并放入数组中,然后再将属性值转换为json字符串;
  • groups[group] = groups[group] || [],在js中对象也是关联数组,因此这里相当于做了两件事,一是把group作为groups的key,二是将对应的value初始化,第一次执行为空数组,循环执行时找到相同的name时保持不变;
  • groups[group] = groups[group] || [],这里也可以写成groups[group] = [],这样的话每次push进去的数据就会覆盖之前的数据,从而达到每次都能获取同一时间段内的最新数据。
  • groups[group].push([element,group]),这句相当于把list中每个对象压入数组中作为value;

2.sortData()函数

  写好groupBy函数后就可以调用进行排序了:

sortData: function(Data){
    var sorted = this.groupBy(Data, function(item){
      return new Date(item.timestamp * 1000).getHours(); // 返回需要分组的对象
      // return item.name; // 返回需要分组的对象
    });
    return sorted;
  },

  这里的return可以返回数组中参数进行比较,比如item中name属性。item是groupBy函数func(element)中的element

二、ECS6箭头函数写法

  上面是ECS5的写法,到了ECS6之后JS就引入箭头函数,下面是ECS6含箭头函数的写法。

1.sortClass()函数

sortClass(Data){
  const groupBy = (array, func) => {
    let groups = {};
    array.forEach((element)=>{
      let group = JSON.stringify(func(element));
      groups[group] = groups[group] || [];
      groups[group].push(element);
    });
    return Object.keys(groups).map((group) =>{
      return groups[group];
    })
  };
  const sorted = groupBy(Data, (item) =>{
    return item.name;
  })
  return sorted;
}

2.运行结果

  这就是运行sortClass(res.query)之后得到的结果,这里本人是timestamp时间戳来进行排序,而红框中的数据就是push[element,group]中的group。

三、按需聚合(结合实际使用)

  上面是对数据库中数据聚合得到是数组每个key对于都是当前最新的值(只有一个),如果这里要求要保留每个key都对于两个最新的值,则需要对groupBy函数进行改动一下了。

1.groupBy()函数

/**
   * author: CSH
   * 函数功能:给定参数对数组进行分组并排序
   * @param {Object} array [需要排序的数组]
   * @param {Object} func [该函数参数用于返回用于分组排序的对象]
   */
  groupBy: function(array, func){
    var groups = {};
    array.forEach(function(element){
      var group = JSON.stringify(func(element));
      groups[group] = groups[group] || []; //第一次执行为空数组
      
      // groups[group] = [];  // 这样就能得到当前小时时间段内最新的数据
      groups[group].push([element,group]);
      groups[group].length >= 3 ? groups[group].shift() : null; // 只保留当前数组最新两组数据
    });
    return Object.keys(groups).map(function(group){
      return groups[group];
    });
  },

  在js中对数组只保留最新两项数据需要用到JS中数组里的 shift()方法 (位移元素)了,位移与弹出等同,但处理首个元素而不是最后一个。shift() 方法会删除首个数组元素,并把所有其他元素“位移”到更低的索引了(类似于队列一样)。使用该方法就可以保证数组内的元素都是最新两项。

2.sortData()函数(无改动)

/**
   * author: CSH
   * 函数功能:给定数组,并返回需要分组的对象,然后根据该对象进行分组排序返回新的数组 
   * @param {Object} sortData [需要数据聚合的数组]
   */
  sortClass: function(sortData){
    var sorted = this.groupBy(sortData, function(item){
      return new Date(item.timestamp * 1000).getHours(); // 返回需要分组的对象
      // return item.name; // 返回需要分组的对象
    });
    return sorted;
  },

  对groupBy()函数进行改动之后,在用sortData进行调用返回就能得到想要的数据了。


总结

  以上就是今天要讲的内容,本文仅仅简单介绍了JS数据聚合的方法,ECS5和ECS6分别都有不同的写法。

  感谢观看,如果有帮助到你,请给文章点个赞和收藏,让更多的人看到。🌹 🌹 🌹

  也欢迎你,关注我。👍 👍 👍

  原创不易,还希望各位大佬支持一下,你们的点赞、收藏和留言对我真的很重要!!!💕 💕 💕 最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!


相关文章
|
12天前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
24 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
12天前
|
JavaScript 前端开发 开发者
.js的dom元素操作
【10月更文挑战第29天】通过灵活运用这些 DOM 元素操作方法,JavaScript 可以实现丰富的网页交互效果,如动态更新页面内容、响应用户操作、创建和删除页面元素等。在实际开发中,开发者可以根据具体的需求和场景,选择合适的 DOM 元素操作方法来实现所需的功能,为用户提供更加流畅和动态的网页体验。
|
10天前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
25天前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
27天前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
1月前
|
自然语言处理 前端开发 JavaScript
🛠️ JavaScript数组操作指南:20个精通必备技巧🚀
本文详细介绍了 JavaScript 中的 20 个高效数组操作技巧,涵盖了从基本的添加、移除元素,到数组转换和去重等高级操作。强调了不可变性的重要性,提供了清晰的代码示例,帮助开发者编写更整洁和高效的代码。无论是新手还是经验丰富的开发者,这些技巧都将显著提升您的编码能力,使您在项目中更具竞争力。
22 2
|
1月前
|
JavaScript 前端开发 测试技术
JS都有哪些操作数组的方法
JS都有哪些操作数组的方法
20 3
|
1月前
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
31 1
|
30天前
|
存储 JavaScript 前端开发
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
17 0
|
1月前
|
JavaScript 前端开发 API
JS中数组的方法flat()怎么用
JS中数组的方法flat()怎么用
13 0