有一个包含K个元素的数组。获得 N 块的最佳方法是什么 < K items from this array?
输入示例:
$x = [1,2,3,4,5,6,7,8,9,10]; // K = 10
期望的结果,当 N = 3 时;
$x1 = [1,2,3];
$x2 = [4,5,6];
$x3 = [7,8,9];
$x4 = [10];
显然,不需要将结果存储在变量中。只要可以通过 foreach (或任何其他迭代逻辑)处理它,就应该没问题。
array_slice
的问题是它不会从数组的开头删除 N 切片。 array_shift
的问题是它不支持一次移动超过 1 个项目。还有什么比迭代array_shift
更优雅的事情吗?
array_chunk
就是您所需要的。
<?php
$x = [1,2,3,4,5,6,7,8,9,10];
print_r(array_chunk($x,3));
输出:
Array
(
[0] => Array
(
[0] => 1
[1] => 2
[2] => 3
)
[1] => Array
(
[0] => 4
[1] => 5
[2] => 6
)
[2] => Array
(
[0] => 7
[1] => 8
[2] => 9
)
[3] => Array
(
[0] => 10
)
)
查看 array_chunk -> http://www.w3schools.com/php/func_array_chunk.asp
$x = [1,2,3,4,5,6,7,8,9,10];
print_r(array_chunk($x,3,true));
或者你可以这样做 -
$x = [1,2,3,4,5,6,7,8,9,10];
$chunks = array();
while(count($x)){
$chunks[] = array_splice($x, 0,3,array());
$i++;
}
有人可以告诉我哪种方法更有效吗?
array_chunk 函数用于创建大小相等的子数组。 例如
$a=array_chunk($array,3);