文章目录

  • 前言
  • 一、数据聚合
    • 1.groupBy()函数
    • 2.sortData()函数
  • 二、ECS6箭头函数写法
    • 1.sortClass()函数
    • 2.运行结果
  • 三、按需聚合(结合实际使用)
    • 1.groupBy()函数
    • 2.sortData()函数(无改动)
  • 总结

前言

  今天在打算从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.运行结果

  这就是运行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函数相关推荐

  1. php js动态删除数组元素,javascript如何删除数组中的指定元素

    js删除数组中的指定元素主要分为两步,首先判断数组中是否包含这个元素,然后再通过splice()方法来删除指定元素 本篇文章主要介绍的是如何通过javascript语言对数组中的指定元素进行删除的方法 ...

  2. JavaScript 找出数组中重复的元素

    实现检测数组重复元素的功能,需要注意一点的是,多个(2个或2个以上)重复元素,我们只需要挑出一个来就可以了. <!DOCTYPE html> <html><head> ...

  3. JavaScript 专题(九)数组中查找指定元素

    JavaScript 专题(九)数组中查找指定元素 上一篇文章中,我们了解了数组扁平化的思想,并学习了 lodash 是如何处理数组扁平化的. 这次我们来讨论在数组中查找元素时所用的一些方法,并且参考 ...

  4. js数组查找最接近_在JavaScript数组中找到最小元素的位置

    在JavaScript数组中找到最小元素的位置 注*  之前有篇文章介绍过数据遍历的性能比较: for in 比for loop慢至少20倍 ,这是另外一篇比较数组查找性能的例子,通过对手工/inde ...

  5. 8种在JavaScript数组中查找指定元素的方法

    来源 | https://www.fly63.com 前言 有时候我们想以某种条件来查找一个数组中是否有满足改条件的元素,然后返回该元素,或者该元素的索引值. JavaScript 给我们提供了多种方 ...

  6. Javascript循环删除数组中元素的3种方法

    本文主要跟大家分享了关于Javascript循环删除数组中元素的几种方法,分享出来供大家参考学习,下面与微点阅读小编一起来看看详细的介绍: 问题 大家在码代码的过程中,经常会遇到在循环中移除指定元素的 ...

  7. JavaScript - 移除数组中的空字符串元素

    移除数组中的空字符串元素 使用 filter 方法对数组进行拷贝,删除空字符串元素,保留其他元素(第 22 ~ 24 行): <!DOCTYPE html> <html>< ...

  8. 8种在JavaScript数组中查找指定元素的方法(用于开发中数据的处理)

    1.Array.prototype.includes() includes() 方法用来判断一个数组是否包含一个指定的值,如果包含则返回 true,否则返回 false. 该方法支持两个参数value ...

  9. php 数组重复最多,PHP获取数组中重复最多元素的简单示例

    这篇文章主要为大家详细介绍了PHP获取数组中重复最多元素的简单示例,具有一定的参考价值,可以用来参考一下. 感兴趣的小伙伴,下面一起跟随512笔记的小玲来看看吧! 本文实例讲述了PHP获取数组中重复最 ...

最新文章

  1. jQuery通过name获取值
  2. C++ Primer 5th笔记(chap 13 拷贝控制)阻止拷贝
  3. Java数据校验(Bean Validation / JSR303)
  4. C#接口-接口的继承
  5. 如何选择合适的监视器?
  6. mongo-rename操作
  7. Spring Boot:(四)开发Web应用之JSP篇
  8. Android 系统性能优化(79)---提升Android应用的启动速度与设计
  9. html 页面怎么自动定位到某个标签,JS如何实现在页面上快速定位(锚点跳转问题)...
  10. ubuntu14.04下python2.7推荐系统Crab搭建
  11. CentOS笔记-系统概述
  12. C课设/宾馆客房管理系统/内附源码
  13. java 抓取搜狗微信_大虾们,求帮助……用httpclient 进行获取微信搜狗公众号文章问题...
  14. 信息搜索的基本技能总结
  15. 全球科学家公认的高效学习法——费曼学习法
  16. 迅雷离线下载 linux,linux 下使用迅雷离线下载
  17. 对一批编号为1~100,全部开关朝上(开)的灯进行以下操作:凡是1的倍数反方向拨一次开关;2的倍数反方向又拨一次开关;3的倍数反方向又拨一次开关……问:最后为关熄状态的灯的编号。
  18. 需求工程-学习通习题-太原理工大学(14-17章)
  19. 多视图几何的数学基础知识的掌握(2)--李群李代数
  20. konga 安装部署

热门文章

  1. 【Redis学习】解决使用redisTemplate 时 存入redis 的key 出现 \xac\xed\x00\x05t\x00
  2. 瑞典军事研究:从认知心理学的视角探讨军事创新进程
  3. PHP递归法因式分解,C++实现 递归算法 - 赏金问题 - 整数因式分解
  4. "熊猫烧香"隐患未消 "小不点"将再掀风浪
  5. Webrtc新增FFmpeg视频编解码模块
  6. GNU sed 4.5 版参考文档全文翻译 各命令和随带20个示例详细解析(四)
  7. 企业为什么要建立私有云
  8. 计算机网络挑战,中国高校计算机网络技术挑战赛
  9. java eden s0 s1_不是吧!做了两年java还没弄懂JVM堆?进来看看你就明白了
  10. 七牛云存储——许式伟