Разделение массива на два массива
У меня есть массив (строк) с n узлами. Каждый узел содержит 6 элементов.
Пример:
rows[0]: ["1", "Text", "0", "55", "0", "Text 2"]
rows[1]: ["2", "Another Text", "15.5", "55", "16.6", "Another Text 2"]
...
rows[n]: [...]
Я хочу поставить второй элемент (как ["Text", "Another Text", ...])
из всех строк [n] в отдельный массив
а также
Хочу поставить третий и пятый элементы (вроде [[0, 0], [15.5, 16.6], ...]
) в отдельный массив тоже. Я думаю мне нужно foreach
в foreach
,
4 ответа
Решение
Это один из нескольких подходов (он использует Array#forEach
),
let arrays = [
["1", "Text", "0", "55", "0", "Text 2"],
["2", "Another Text", "15.5", "55", "16.6", "Another Text 2"]
];
let withIndex1 = [];
let withIndex2And4 = [];
arrays.forEach((arr) => {
withIndex1.push(arr[1]);
withIndex2And4.push([arr[2],arr[4]]);
});
Не так красиво, но я думаю, что более читабельным
let row = [
["1", "Text", "0", "55", "0", "Text 2"],
["2", "Second Text", "15.5", "55", "16.6", "Second Text 2"],
["3", "Third Text", "17", "60", "18", "Third Text 2"]
];
let arrA = [], arrB = [];
function newArrA(el, arr) {
arr.forEach(arrEl => arrA.push(arrEl[el-1]));
}
function newArrB(elA, elB, arr) {
arr.forEach(arrEl => arrB.push( [ arrEl[elA-1], arrEl[elB-1] ] ) );
}
newArrA(2, row);
// arrA: ["Text", "Second Text", "Third Text"]
newArrB(3, 5, row);
// arrB[0]: ["0", "0"]
// arrB[1]: ["15.5", "16.6"]
// arrB[2]: ["17", "18"]
Вы можете сделать это с помощью простого Array#map
:
const rows = [
["1", "Text", "0", "55", "0", "Text 2"],
["2", "Another Text", "15.5", "55", "16.6", "Another Text 2"],
];
const r = (d, n) => rows.map((arr) => arr[n]);
console.log(r(rows, 1));
console.log(r(rows, 2));
Вы можете транспонировать матрицу, взять нужные столбцы и снова транспонировать для получения желаемого результата.
const
transpose = (r, a) => a.map((v, i) => [...(r[i] || []), v]),
array = [["1", "Text", "0", "55", "0", "Text 2"], ["2", "Another Text", "15.5", "55", "16.6", "Another Text 2"]],
columns = array.reduce(transpose, []),
ad1 = columns[1],
ad2 = [columns[2], columns[4]].reduce(transpose, []);
console.log(ad1);
console.log(ad2);
.as-console-wrapper { max-height: 100% !important; top: 0; }