欢迎来到全国社交动力网络科技有限公司
建站资讯

当前位置: 首页 > 建站资讯 > 建站教程 > PHP教程

php怎么判断二维数组长度_php二维数组长度count与递归统计法【技巧】

作者:网站仿制 来源:php基础教程日期:2025-12-17
PHP中二维数组长度获取有五种方式:一、count($arr)得第一维长度3;二、count($arr, COUNT_RECURSIVE)得全部元素总数9;三、遍历累加各子数组长度得值总数6;四、array_walk_recursive统计叶子节点数为6;五、自定义递归函数可按深度控制统计,如countValues($arr, 1)返回6。

php怎么判断二维数组长度_php二维数组长度count与递归统计法【技巧】

如果您需要获取PHP中二维数组的长度,可能面临不同需求:有的只需要第一维元素个数,有的则需统计所有子元素总数。以下是几种常用且可靠的实现方式:

一、使用count()获取第一维长度

count()函数默认只统计数组第一层级的元素数量,适用于快速获知二维数组包含多少个子数组。

1、定义一个二维数组,例如 $arr = [['a', 'b'], ['c'], ['d', 'e', 'f']];

2、调用 count($arr) 获取其第一维长度。

立即学习“PHP免费学习笔记(深入)”;

3、该调用将返回 3,即外层数组包含3个元素(每个元素本身是一个数组)。

二、使用count()配合COUNT_RECURSIVE参数统计全部元素

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) 遍历外层数组。

Veo Veo

Google 最新发布的 AI 视频生成模型

Veo 567 查看详情 Veo

3、对每个 $sub 调用 is_array($sub) 判断是否为数组。

4、若为数组,则执行 $total += count($sub);

5、循环结束后,$total 的值为 6,即所有子数组内值的总个数。

四、使用array_walk_recursive统计叶子节点数量

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教程 app
上一篇: 一个php怎么添加数组元素_php数组添加元素[]追加与array_push法【技巧】
下一篇: php怎么循环截取字符串数组_php循环截字符串数组substr与循环拼接法【教程】

推荐建站资讯

更多>