Уявіть, у мене такий масив JS:
var a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];
Я хочу поділити цей масив на N менших масивів. Наприклад:
split_list_in_n(a, 2)
[[1, 2, 3, 4, 5, 6], [7, 8, 9, 10, 11]]
For N = 3:
[[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11]]
For N = 4:
[[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11]]
For N = 5:
[[1, 2, 3], [4, 5], [6, 7], [8, 9], [10, 11]]
Для Python я маю таке:
def split_list_in_n(l, cols):
""" Split up a list in n lists evenly size chuncks """
start = 0
for i in xrange(cols):
stop = start + len(l[i::cols])
yield l[start:stop]
start = stop
Для JS найкращим правильним рішенням, яке я міг би придумати, є рекурсивна функція, але мені це не подобається, оскільки це складно і негарно. Ця внутрішня функція повертає масив, подібний до цього [1, 2, 3, null, 4, 5, 6, null, 7, 8], а потім мені доведеться його повторно прокрутити та розділити вручну. (Моєю першою спробою було повернення цього: [1, 2, 3, [4, 5, 6, [7, 8, 9]]], і я вирішив зробити це за допомогою нульового роздільника).
function split(array, cols) {
if (cols==1) return array;
var size = Math.ceil(array.length / cols);
return array.slice(0, size).concat([null]).concat(split(array.slice(size), cols-1));
}
Ось jsfiddle цього: http://jsfiddle.net/uduhH/
Як би ви це зробили? Дякую!