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

文章目录

  • 前言
  • 一、数据聚合
    • 1.groupBy()函数
    • 2.sortData()函数
  • 二、ECS6箭头函数写法
    • 1.sortClass()函数
    • 2.运行结果
  • 总结


前言

今天在打算从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组成的新数组,返回分好了组的二维数组

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

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

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


总结

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

你可能感兴趣的:(JavaScript,javascript,json,前端)