PHP中二维数组长度获取有五种方式:一、count($arr)得第一维长度3;二、count($arr, COUNT_RECURSIVE)得全部元素总数9;三、遍历累加各子数组长度得值总数6;四、array_walk_recursive统计叶子节点数为6;五、自定义递归函数可按深度控制统计,如countValues($arr, 1)返回6。

如果您需要获取PHP中二维数组的长度,可能面临不同需求:有的只需要第一维元素个数,有的则需统计所有子元素总数。以下是几种常用且可靠的实现方式:
count()函数默认只统计数组第一层级的元素数量,适用于快速获知二维数组包含多少个子数组。
1、定义一个二维数组,例如 $arr = [['a', 'b'], ['c'], ['d', 'e', 'f']];
2、调用 count($arr) 获取其第一维长度。
立即学习“PHP免费学习笔记(深入)”;
3、该调用将返回 3,即外层数组包含3个元素(每个元素本身是一个数组)。
COUNT_RECURSIVE标志使count()递归遍历所有层级,统计整个二维数组中所有标量值和子数组的总数量(注意:子数组本身也被计入)。
1、定义同上二维数组 $arr = [['a', 'b'], ['c'], ['d', 'e', 'f']];
2、调用 count($arr, COUNT_RECURSIVE) 获取递归计数结果。
3、该调用将返回 9,其中包含3个子数组 + 6个字符串值。
若仅需统计所有子数组中“值”的总数(排除子数组自身),需逐层遍历并累加各子数组的count()结果。
1、初始化计数器 $total = 0;
2、使用 foreach ($arr as $sub) 遍历外层数组。
3、对每个 $sub 调用 is_array($sub) 判断是否为数组。
4、若为数组,则执行 $total += count($sub);
5、循环结束后,$total 的值为 6,即所有子数组内值的总个数。
array_walk_recursive() 只访问数组中“非数组”的最终值(即叶子节点),适合精确统计所有实际数据项数量。
1、定义空数组 $leaves = [];
2、调用 array_walk_recursive($arr, function($item) use (&$leaves) { $leaves[] = $item; });
3、对 $leaves 执行 count($leaves) 获取叶子节点总数。
4、该方法返回的结果为 6,与手动遍历累加结果一致,且不依赖子数组结构深度。
当二维数组可能存在不规则结构(如部分元素为null、字符串或更深嵌套),可编写可控递归函数区分统计逻辑。
1、定义函数 function countValues($array, $depth = 1) { if (!is_array($array)) return 0; if ($depth === 0) return 1; $sum = 0; foreach ($array as $item) { $sum += is_array($item) ? countValues($item, $depth - 1) : 1; } return $sum; }
2、调用 countValues($arr, 1) 表示最多深入1层(即只统计第二层值),结果为 6。
3、调用 countValues($arr, 0) 表示将每个数组元素视为单个值,结果为 3。
以上就是php怎么判断二维数组长度_php二维数组长度count与递归统计法【技巧】的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号