JavaScript数组中相同的元素进行分组(数据聚合)groupBy函数详解

 更新时间:2023年12月19日 11:54:49   作者:我是夜阑的狗  
今天在打算从js端时序数据库TSDB中,按相同的类型的数据排在一起,并且取同一时间段最新的数据,经过查询这种思想叫做数据聚合,就是返回的数据要根据一个属性来做计算,这篇文章主要介绍了JavaScript数组中相同的元素进行分组(数据聚合) groupBy函数,需要的朋友可以参考下

前言

  今天在打算从js端时序数据库TSDB中,按相同的类型的数据排在一起,并且取同一时间段最新的数据,经过查询这种思想叫做数据聚合,就是返回的数据要根据一个属性来做计算。

一、数据聚合

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分别都有不同的写法。

到此这篇关于JavaScript数组中相同的元素进行分组(数据聚合) groupBy函数的文章就介绍到这了,更多相关js数组分组groupBy函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript实现简单版的留言发布与删除

    JavaScript实现简单版的留言发布与删除

    这篇文章主要介绍了如何通过JavaScript实现简单的留言板功能:留言的发布与删除。文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
    2022-03-03
  • 详解JavaScript执行模型

    详解JavaScript执行模型

    这篇文章主要介绍了JavaScript执行模型的相关资料。帮助大家更好的理解和学习JavaScript,感兴趣的朋友可以了解下
    2020-11-11
  • 微信小程序实现简易table表格

    微信小程序实现简易table表格

    这篇文章主要为大家详细介绍了微信小程序实现简易table表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • 利用javascript如何随机生成一定位数的密码

    利用javascript如何随机生成一定位数的密码

    这篇文章主要给大家介绍了关于利用javascript如何随机生成一定位数的密码的相关资料,文中给出了详细的示例代码,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-09-09
  • JS实现简易刻度时钟示例代码

    JS实现简易刻度时钟示例代码

    本篇文章主要介绍了JS实现简易刻度时钟示例代码的资料,这里整理了详细的代码,有需要的小伙伴可以参考下。
    2017-03-03
  • JS正则表达式常见用法实例详解

    JS正则表达式常见用法实例详解

    这篇文章主要介绍了JS正则表达式常见用法,结合实例形式分析了javascript元字符、分组符、修饰符、量词基本含义,并结合具体案例形式分析了javascript正则基本使用技巧,需要的朋友可以参考下
    2018-06-06
  • 用js来定义浏览器中一个左右浮动元素相对于页面主体宽度的位置的函数

    用js来定义浏览器中一个左右浮动元素相对于页面主体宽度的位置的函数

    用js来定义浏览器中一个左右浮动元素相对于页面主体宽度的位置的函数 函数的参数:elem元素、页面主体宽度(如:990、950宽)、elem与页面主体DIV的左边距
    2012-01-01
  • JavaScript仿京东实现秒杀倒计时案例详解

    JavaScript仿京东实现秒杀倒计时案例详解

    这篇文章主要为大家详细介绍了如何利用JavaScript实现京东秒杀倒计时效果,文中示例代码介绍的非常详细,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • javascript与Python快速排序实例对比

    javascript与Python快速排序实例对比

    这篇文章主要介绍了javascript与Python快速排序实例对比,实例讲述了javascript与Python实现快速排序的简单实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • JavaScript面向对象编程小游戏---贪吃蛇代码实例

    JavaScript面向对象编程小游戏---贪吃蛇代码实例

    这篇文章主要介绍了JavaScript贪吃蛇的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05

最新评论