2017-07-10 65 views
1

我是nodejs的新手,我需要劃分一個數組,其中包含x軸上的日期和y軸上的點,並嘗試使用數組繪製圖形來存儲數據X和Y軸做我這樣做:如何在nodejs中將數組劃分爲相等部分

while(startDate <= endDate) 
{ 
    arr.push({x:startDate.toISOString().slice(0,10),y: 0}); 
    startDate.setDate(startDate.getDate() + 1); 
} 

它都從起始日期的日期存儲到結束日期,現在我需要把它分成幾個星期,所以我發現周:

var Weeks = Math.round((endDate - startDate)/(7 * 24 * 60 * 60 * 1000)); 

現在去哪個日期有一個點,所以我做:

for (var i = doc.length - 1; i >= 0; i--) { 
    for (var j = arr.length - 1; j >= 0; j--) { 
     if (arr[j].x == doc[i].deal_end_date) { 
      arr[j].y ++; 
      } 
     }  
    } 
} 

現在這會給我下面的輸出:

startDate: 2017-07-10, endDate: 2017-07-31 


arr : 
[ { x: '2017-07-10', y: 1 }, 
     { x: '2017-07-11', y: 0 }, 
     { x: '2017-07-12', y: 0 }, 
     { x: '2017-07-13', y: 0 }, 
     { x: '2017-07-14', y: 0 }, 
     { x: '2017-07-15', y: 1 }, 
     { x: '2017-07-16', y: 0 }, 
     { x: '2017-07-17', y: 0 }, 
     { x: '2017-07-18', y: 0 }, 
     { x: '2017-07-19', y: 0 }, 
     { x: '2017-07-20', y: 0 }, 
     { x: '2017-07-21', y: 0 }, 
     { x: '2017-07-22', y: 0 }, 
     { x: '2017-07-23', y: 0 }, 
     { x: '2017-07-24', y: 0 }, 
     { x: '2017-07-25', y: 0 }, 
     { x: '2017-07-26', y: 0 }, 
     { x: '2017-07-27', y: 0 }, 
     { x: '2017-07-28', y: 0 }, 
     { x: '2017-07-29', y: 0 }, 
     { x: '2017-07-30', y: 0 }, 
     { x: '2017-07-31', y: 0 } ] 

現在我需要這個數組即ARR分爲周, 我試圖

var i,j,temparray,chunk = Weeks; 
for (i=0,j=arr.length; i<j; i+=chunk) { 
    temparray = arr.slice(i,i+chunk); 
} 

但在temparray存儲作爲:

temparray: [ { x: '2017-07-31', y: 0 } ] 

而我需要我的臨時陣列作爲b elow:

startDate: 2017-07-01 endDate: 2017-07-28 
Weeks: 4 
/*temparray[1] should be from arr[0] to arr[6]*/ 
temparray[1] : 
[ { x: '2017-07-01', y: 0 }, 
    { x: '2017-07-02', y: 0 }, 
    { x: '2017-07-03', y: 0 }, 
    { x: '2017-07-04', y: 0 }, 
    { x: '2017-07-05', y: 1 }, 
    { x: '2017-07-06', y: 0 }, 
    { x: '2017-07-07', y: 0 }] 
/*temparray[2] should be from arr[7] to arr[13]*/ 
temparray[2] : 
[ { x: '2017-07-08', y: 0 }, 
    { x: '2017-07-09', y: 0 }, 
    { x: '2017-07-10', y: 0 }, 
    { x: '2017-07-11', y: 0 }, 
    { x: '2017-07-12', y: 0 }, 
    { x: '2017-07-13', y: 0 }, 
    { x: '2017-07-14', y: 0 }] 
/*temparray[3] should be from arr[14] to arr[20]*/ 
temparray[3] : 
[ { x: '2017-07-15', y: 0 }, 
    { x: '2017-07-16', y: 0 }, 
    { x: '2017-07-17', y: 0 }, 
    { x: '2017-07-18', y: 0 }, 
    { x: '2017-07-19', y: 0 }, 
    { x: '2017-07-20', y: 0 }, 
    { x: '2017-07-21', y: 0 }] 
/*temparray[4] should be from arr[21] to arr[27]*/ 
temparray[4] : 
[ { x: '2017-07-22', y: 0 }, 
    { x: '2017-07-23', y: 0 }, 
    { x: '2017-07-24', y: 0 }, 
    { x: '2017-07-25', y: 0 }, 
    { x: '2017-07-26', y: 0 }, 
    { x: '2017-07-27', y: 0 }, 
    { x: '2017-07-28', y: 0 }] 

回答

1

使用fillmap A液:

function splitArray(array, chunkSize) { 
 
    return Array(Math.ceil(array.length/chunkSize)).fill().map(function(_,i) { 
 
    return array.slice(i * chunkSize, i * chunkSize + chunkSize); 
 
    }); 
 
} 
 

 
var results = splitArray([1,2,3,4,5,6,7,8], 3); 
 
console.log(results);

你能適應它使用日期

+0

感謝它工作的人+1 –

1

如回答@Alberto特林達德塔瓦雷斯我只是做它通過:

/* arr is my original array */ 
var ressu = splitArray(arr, 7); 

function splitArray(arr, chunkSize) { 
    return Array(Math.ceil(arr.length/chunkSize)).fill().map(function(_,i) { 
    return arr.slice(i * chunkSize, i * chunkSize + chunkSize); 
    }); 
}