如何根据子数组元素状态拆分数组?

时间:2019-01-23 07:08:00

标签: javascript arrays underscore.js

我有一个由子数组组成的数组:

myArray  = [[info1, info2, info3, value1], [info1, info2, info3, value1], 
[info1, info2, info3, value1],.............]

我想基于“ value1”将数组拆分为几个数组。如果value1在大于5的连续元素中大于1000,我想创建一个新数组:

mySubArray1 = [[info1, info2, info3, 1011], [info1, info2, info3, 
1012], [info1, info2, info3, 1011],.............]

因此,如果我发现第二个系列的value1大于1000的元素超过了5个连续元素,我想创建另一个数组:

mySubArray2 = [[info1, info2, info3, 3030], [info1, info2, info3, 
4000], [info1, info2, info3, 1700],.............]

我的工作如下:

var j;
for (j = 0; j < array.length; j++) {
if (array[j][3] < 1000 ) {

    console.log("below 1000");
}
else {
    console.log("above 1000");
}

}

这可以检测到值大于1000的位置,但是现在我需要将其分类到新的数组中,而且我不知道如何开始该过程。

1 个答案:

答案 0 :(得分:2)

您应该能够执行Array.reduce以获得所需的结果:

我正在生成一个与您的输入类似的数组,'value1'的值将介于995和1010之间。

function getRandomInt(min, max) {
    return Math.floor(Math.random() * (max - min + 1)) + min;
}

let myArray  = [...Array(100).keys()].map(n => ['info1', 'info2', 'info3', getRandomInt(995, 1010)]);

console.log("Input: ", JSON.stringify(myArray));

let subArray = [];
// Result will contain a list of our new subarrays.
let result = myArray.reduce((acc, val, index) => {

   if (val[3] >= 1000) { 
      subArray.push(val);
   } 

   if ((val[3] < 1000) || (index === myArray.length - 1) /* Handle the case when we're at the end of myArray */ ) {
       if (subArray.length > 5) { 
           acc.push(subArray);
       } 
       subArray = [];
   }
 
   return acc;
}, [])

console.log("Result:");
result.forEach( (subArray, n) => console.log(`Subarray ${n+1}: `, subArray));