亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - 如何將一個(gè)長(zhǎng)為365的數(shù)組對(duì)象按月份切割成12組?

瀏覽:142日期:2023-04-13 13:33:59

問(wèn)題描述

如圖是一個(gè)json文件,存放了2014年全年的AQI數(shù)據(jù),現(xiàn)在想算出每月平均AQI,請(qǐng)問(wèn)該如何處理這個(gè)數(shù)組?

javascript - 如何將一個(gè)長(zhǎng)為365的數(shù)組對(duì)象按月份切割成12組?

問(wèn)題解答

回答1:

arr.reduce((r,v)=>r[v.date.split(’/’)[1]-1].push(v)&&r,new Array(12).fill(0).map(_=>[]))

這個(gè)返回結(jié)果就可以返回一個(gè)包含12個(gè)數(shù)組的新數(shù)組,每個(gè)子數(shù)組里包含了當(dāng)月的AQI數(shù)據(jù)

才發(fā)現(xiàn)樓主要的是求每個(gè)月的平均AQI,那么可以這樣:

arr.reduce((r,v)=>r[v.date.split(’/’)[1]-1].push(v)&&r,new Array(12).fill(0).map(_=>[])) .map((i,k)=>{let r = i.reduce((r,v)=>{for(let j in r)r[j]+=(+v[j]);return r},{beijing:0,shanghai:0,guangzhou:0});for(let j in r) r[j] = parseInt(r[j]/i.length);return {...r,month:k+1+’月’}})

這個(gè)結(jié)果返回一個(gè)包含12個(gè)形如{month:’1月’,beijing:12,shanghai:24,guangzhou:36}的數(shù)組,里面的值就是每個(gè)月的平均值。

回答2:

后臺(tái)group by一下,用avg()

回答3:

感覺你不需要對(duì)數(shù)據(jù)進(jìn)行處理,那樣只會(huì)繼續(xù)耗費(fèi)內(nèi)存,你這里只需要知道每個(gè)月起始點(diǎn)和結(jié)束點(diǎn),通過(guò)起始點(diǎn)和結(jié)束點(diǎn)去取數(shù)組進(jìn)行計(jì)算就好了.因?yàn)槠鋵?shí)數(shù)據(jù)都在這里了,只是你使用數(shù)據(jù)規(guī)則不一樣罷了

回答4:

你的問(wèn)題主要是怎么分成12組,提供兩個(gè)簡(jiǎn)單的思路

將date變成日期對(duì)象,取月份來(lái)分組

利用正則取匹配date來(lái)分組

回答5:

從你給出的JSON格式分析得出:

外圍數(shù)組1-12,代表12個(gè)月

再遍歷數(shù)組,得到object,取object的data值,按照/分割得到月,根據(jù)月份把object填充到對(duì)應(yīng)月份中

拿到每個(gè)月對(duì)應(yīng)的數(shù)據(jù),再按月處理

回答6:

數(shù)據(jù)分組讓后端處理吧,前端負(fù)責(zé)使用就好了。

回答7:

var jsonData = [{ ’date’: ’2014/1/1’, ’beijing’: 80, ’shanghai’: 123, ’guangzhou’: 99 },{ ’date’: ’2014/1/2’, ’beijing’: 80, ’shanghai’: 123, ’guangzhou’: 99 },{ ’date’: ’2014/2/1’, ’beijing’: 80, ’shanghai’: 123, ’guangzhou’: 99 }];// 保存的json數(shù)據(jù)var arr = [{’date’: ’1’, ’b’: 0, ’s’: 0, ’g’: 0}];var k = 0;for(var i = 0; i < jsonData.length; i++) { var item = jsonData[i]; var dateArr = item.date.split(’/’); if (dateArr[1] == arr[k].date) {arr[k].b += item.beijing;arr[k].s += item.shanghai;arr[k].g += item.guangzhou; } else {var param = { ’date’: dateArr[1], ’b’: 0, ’s’: 0, ’g’: 0};k++;arr.push(param); }}console.log(arr);

上面代碼將每個(gè)月份的數(shù)據(jù)求和了,要請(qǐng)平均應(yīng)該簡(jiǎn)單了,不過(guò)上面的代碼對(duì)json數(shù)據(jù)有個(gè)要求就是需要所有的數(shù)據(jù)已經(jīng)按照月份分類好了

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: aaaaaa级特色特黄的毛片 | 国产黄色片在线免费观看 | 日韩欧美在线看 | 中文字幕 亚洲 一区二区三区 | 免费看日韩欧美一级毛片 | 男女男精品视频网站在线观看 | 日本欧美一区二区三区在线 | 热99re久久精品这里都是免费 | 99久久精品免费国产一区二区三区 | 美女一级免费毛片 | 国产欧美精品一区二区三区四区 | 全部毛片| 久久久久日韩精品无 | 久久九九国产精品怡红院 | 99ri在线视频 | 精品国产成人a区在线观看 精品国产成人a在线观看 | 亚洲一区二区三区四区五区 | 欧美成人性色xxxxx视频大 | 99精品在线观看视频 | 国产区高清 | 国产精品一区二区在线观看 | 国产成人精品一区二区秒拍 | 波多野结衣3女同在线观看 波多野结衣aⅴ在线 | 欧美一区二区三区视频 | 久久久久久久久网站 | 日本精品中文字幕有码 | 国产乱子伦在线观看不卡 | 国产精品99r8免费视频2022 | 99久久精品免费观看区一 | 国产三级a三级三级天天 | 久久永久免费视频 | www成人免费视频 | 99热在线获取最新地址 | 亚洲一区二区三区香蕉 | 国内自拍视频在线看免费观看 | 欧美一级毛片在线观看 | 欧美国产亚洲一区 | 精品综合久久久久久99 | 香港国产特级一级毛片 | 激情视频一区 | 91热久久免费精品99 |