JSON数据-使用Javascript/Jquery按星期几(太阳、周一、周二、周三、周四、周五、周六)分组

JSON数据-使用Javascript/Jquery按星期几(太阳、周一、周二、周三、周四、周五、周六)分组,javascript,jquery,json,Javascript,Jquery,Json,下面的函数返回图表数据 上述函数返回的输出格式如下 [Object { date=Date, value=112, volume=1469}, Object { date=Date, value=124, volume=539}, Object { date=Date, value=114, volume=859}, Object { date=Date, value=123, volume=1284}, Object { date=Date, value=113, volu

下面的函数返回图表数据

上述函数返回的输出格式如下

[Object { date=Date,  value=112,  volume=1469}, Object { date=Date,  value=124,  volume=539}, Object { date=Date,  value=114,  volume=859}, Object { date=Date,  value=123,  volume=1284}, Object { date=Date,  value=113,  volume=1382}, Object { date=Date,  value=129,  volume=1353}]
从上面的
getChartData
生成的输出中,我渴望看到以下类型的输出,其中01,02等是月数。这基本上是将数据聚合到每月的星期几级别

[{'dayofweek':'01-SUN','value':xxx,'volume':'yyy},{'dayofweek':'01-MON','value':xxx,'volume':'yyy},{'dayofweek':'01-TUE','value':xxx,'volume':'yyy},{'dayofweek':'01-WED','value':xxx,'volume':'yyy},{'dayofweek':'01-THU','value':xxx,'volume':'yyy},{'dayofweek':'01-FRI','value':xxx,'volume':'yyy},{'dayofweek':'01-SAT','value':xxx,'volume':'yyy}]
我将
JSON.stringify
数组的
getChartData
输出如下所示(显示此项以便
'date'
字段的值可见

[{"date":"2014-10-06T06:00:00.000Z","value":119,"volume":1417},{"date":"2014-10-07T06:00:00.000Z","value":126,"volume":1421},{"date":"2014-10-08T06:00:00.000Z","value":140,"volume":850}]
上面的数组有几百个对象。我正在尝试聚合这些对象,以在一周中的某一天(星期日、星期一等的总计)逐月计算
体积
字段的总和

对象数组可以有任何字段。我的意思是,我想写一个动态函数,其中每个对象的第一个元素将是一个日期字段,由任何变量名(日期、xdate、ydate等)表示。除第一个字段外的其余字段(有时可能有2个字段、3个字段或n个字段)每月需要将其相加并汇总到每周的某一天

这就是我正在做的

function setGroupingDayOfWeek(thisObj) {
  var chartData = getChartData("chartdiv");
  var keysOnly = Object.keys(chartData[0]);
  var objStruct = getObjStruct(keysOnly);
  var chartFeedJson = updatejsonStruct(objStruct,chartData)
}


function getObjStruct(keyArray) {
    //  var arrToObjContent = _.values(Object.keys(jsonData[0])),
  var arrToObjContent = keyArray,
    dayOfWeek = ["SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT"],
    i = 0,
    z,
    arrToObjLength = arrToObjContent.length,
    dayOfWeekLength = dayOfWeek.length,
    jsonObj = {},
    newObj,
    key,
    value;

  for (; i < dayOfWeekLength; i++) {
    newObj = {};
    for (z = 0; z < arrToObjLength; z++) {
      key = arrToObjContent[z];

      if (key === arrToObjContent[0]) {
        value = dayOfWeek[i];
      } else {
        value = "";
      }
      newObj[key] = value;
    }
    jsonObj[i] = newObj;
  }
  return jsonObj;
}


function updatejsonStruct(objStruct,chartData) {
    var baseStruct = objStruct,
        chartDataFormatted = JSON.stringify(chartData);
// The idea here is to first group it by months & then loop through & sum up all Sundays, Mondays etc to the end of week
    var groupedByMonth = _.groupBy(chartDataFormatted , function (item) {
        return item[0].substring(0, 9);
    });     
    console.log(groupedByMonth);
}

这是部分动态的。条件是对象的第一个键是日期对象

var-days=[“太阳”、“周一”、“周二”、“周三”、“周四”、“周五”、“周六”]
//我使用了新的日期,它得到了当前的日期,你不需要它。
var chartData=[{日期:新日期,值:112,卷:1469},{日期:新日期,值:124,卷:539},{日期:新日期,值:114,卷:859},{日期:新日期,值:123,卷:1284},{日期:新日期,值:113,卷:1382},{日期:新日期,值:129,卷:1353}];
//在这里使用var chartData=getChartData(“chartdiv”);
keys=Object.keys(chartData[0]);
var newA=chartData.map(函数(val,i){
day=val.date.getDay();
month=(val.date.getMonth()+1.toString();
月=月。长度==2?月:“0”+月;
rtn={};
对于(变量i=0;idocument.write(JSON.stringify(newA))
这是部分动态的。条件是对象的第一个键是日期对象

var-days=[“太阳”、“周一”、“周二”、“周三”、“周四”、“周五”、“周六”]
//我使用了新的日期,它得到了当前的日期,你不需要它。
var chartData=[{日期:新日期,值:112,卷:1469},{日期:新日期,值:124,卷:539},{日期:新日期,值:114,卷:859},{日期:新日期,值:123,卷:1284},{日期:新日期,值:113,卷:1382},{日期:新日期,值:129,卷:1353}];
//在这里使用var chartData=getChartData(“chartdiv”);
keys=Object.keys(chartData[0]);
var newA=chartData.map(函数(val,i){
day=val.date.getDay();
month=(val.date.getMonth()+1.toString();
月=月。长度==2?月:“0”+月;
rtn={};
对于(变量i=0;idocument.write(JSON.stringify(newA))
请参阅以下JS FIDLE链接:

你可以先按月份和日期分组,然后做一个
reduce
,将所有值和数量相加。关于你对其他答案的评论,我认为很难使字段动态化

编辑: 检查更新的小提琴:


请参阅以下JS Fiddle链接:

你可以先按月份和日期分组,然后做一个
reduce
,将所有值和数量相加。关于你对其他答案的评论,我认为很难使字段动态化

编辑: 检查更新的小提琴:


谢谢你,Rejith。它在所有对象中弹出
THU
。我会检查这一点。而且,
chartData
可以有任何字段,第一个字段是日期。那么,我如何使
返回值动态。我的意思是,在回答中,
value
volume
,而在现实场景中,这些字段可以是任何内容。是吗有办法让这个动态吗?@usert4jju7这是因为我提供了
new Date
,它获取当前日期。当然。所以,当我使用函数result时,它会被处理。酷。任何遥远的机会,我们都可以使这些变量动态?`{“dayOfWeek”:“1-SUN”,“value”:212,“volume”:956},{“dayOfWeek”:“2-MON”,“value”:197,“volume”:1244},{“dayOfWeek”:“3-TUE”,“value”:268,“volume”:1696},{“dayOfWeek”:“4-WED”,“value”:302,“volume”:1093},{“dayOfWeek”:“5-THU”,“value”:210,“volume”:1301},{“dayOfWeek”:“6-FRI”,“value”:269,“volume”:1167},{“dayOfWeek”:“0-未定义”,“value”:262,“volume”:1669},`Hello Rejith-输出在上面。这非常有效,只是它不是按月份分组。它是根据一周中的某一天而不是月份来分配1到7个数字(我需要每月总计aka组每月所有星期日、每月所有星期一等等)。此外,星期六变得
未定义
(估计这与数组索引有关)谢谢你,Rejith。它在所有对象中弹出
THU
。我会检查这一点。而且,
chartData
可以有任何字段,第一个字段是日期。那么,我如何使
返回值动态。我的意思是,在回答中,
value
volume
,而在现实场景中,这些字段可以是任何内容。是吗有没有一种方法可以让这个动态化呢?@usert4jju7这是因为
newdatevar days = ["SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT"]
var chartData = getChartData("chartdiv");

//use var chartData = getChartData("chartdiv") here instead;
keys = Object.keys(chartData[0]);
var newObjStruct = [{},{},{},{},{},{},{}];

for(var k = 0; k < days.length; k++){
  for(var i = 0; i < keys.length; i++){
      if (i === 0) {
          newObjStruct[k]['dayOfWeek' ] = days[k];
      } else {
          newObjStruct[k][keys[i]] = "";          
  }
  }
}

console.log(newObjStruct);

for (j=0; j<chartData.length; j++){
var castObj = JSON.stringify(chartData[j]);
console.log(castObj[0]);
//val.date.getDay();
      for(k = 0; k < newObjStruct.length; k++) {
           if (newObjStruct[k][0] === days[day]) {
for(var i = 0; i < keys.length; i++){
              newObjStruct[k][i] += chartData[keys[i]];
          } 
           }          
  }
}
var days = ['SUN', 'MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT', 'SUN'];

var testArray = [{"date":"2014-10-06T06:00:00.000Z","value":119,"volume":1417},{"date":"2014-10-06T06:00:00.000Z","value":119,"volume":1417},{"date":"2014-10-07T06:00:00.000Z","value":126,"volume":1421},{"date":"2014-10-08T06:00:00.000Z","value":140,"volume":850}];

var groupResult = _.groupBy(testArray, function (value) {
  var d = new Date(value.date);
    return (d.getMonth()+1) + "-" + days[d.getDay()]
});

var result = [];

_.each(groupResult, function (value, key) {
  var volumeSum = 0;
  var valueSum = _.reduce(value, function(memo, obj){ 
    //valueSum += obj.value;    
    volumeSum += obj.volume;
    return memo + obj.value; 
  }, 0);
  result.push({ dayofweek: key, value: valueSum, volume: volumeSum });
})
console.log(result);
var result = [];

_.each(groupResult, function (value, key) {
  var doc = _.reduce(value, function(memo, obj){
  delete obj.date;
   if (typeof(memo) == "number") {
    return obj;
   } else {
    for (var key in memo) {
        memo[key] += obj[key] || 0;
    }
    return memo;
   }
  }, 0);
  doc.dayOfWeek = key;
  result.push(doc);
})