php二维数组判断长度_php多维数组大小计算方法【教程】

5次阅读

php中二维数组长度需区分行数、元素总数与列分布:count($arr)得行数;count($arr, COUNT_RECURSIVE)得含子数组的总数;逐行 count()分析列长;array_walk_recursive()精准统计标量元素;json_encode 配合 substr_count 可估算嵌套深度。

php 二维数组判断长度_php 多维数组大小计算方法【教程】

如果您需要获取 PHP 中二维数组的长度或计算 多维数组 的总元素数量,则需区分“维度数量”与“元素总数”两种不同需求。以下是针对该问题的具体操作方法:

一、使用 count()函数计算二维数组的行数

count()函数默认仅统计第一层元素个数,适用于获取二维数组的行数(即外层数组长度)。该函数不 递归 遍历子数组,因此结果仅反映最外层索引数量。

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

2、调用count($arr),返回值为3,表示该二维数组有 3 行。

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

3、若需确保仅统计索引数组且排除关联键干扰,可添加第二个参数COUNT_NORMAL,即count($arr, COUNT_NORMAL)

二、使用 count()配合 COUNT_RECURSIVE 参数统计所有元素总数

COUNT_RECURSIVE 标志使 count()函数递归遍历每一层嵌套结构,将所有标量值(字符串、整数等)及子数组本身均计入总数。注意:此方式会把子数组也当作一个元素计数,若仅需标量总数,需额外过滤。

1、对同一数组 $arr 执行count($arr, COUNT_RECURSIVE)

2、返回值为9,其中包含 3 个子数组和 6 个标量值(’a’,’b’,’c’,’d’,’e’,’f’)。

3、若仅统计标量元素,需结合 is_scalar()进行遍历判断,不可单靠 COUNT_RECURSIVE 直接得出。

三、遍历并累加各子数组长度以获得列维度信息

二维数组每行可能长度不同,需逐行调用 count()获取各子数组长度,从而分析列分布情况。该方法适用于检测不规则二维数组的列数变化。

1、初始化空数组$cols = [];

2、使用 foreach 遍历外层数组:foreach ($arr as $row) {$cols[] = count($row); }

3、此时 $cols 内容为[2, 3, 1],对应各行的列数。

4、可进一步用 max($cols)获取最大列数,或用 array_sum($cols)得到所有列元素之和。

四、使用 array_walk_recursive 提取全部标量值后计数

array_walk_recursive()自动跳过子数组,只对最深层的标量值执行回调。配合引用变量累计,可精确获得纯数据元素总数,规避 COUNT_RECURSIVE 将子数组计入的问题。

1、声明计数变量$scalarCount = 0;

2、调用array_walk_recursive($arr, function($value) use (&$scalarCount) {$scalarCount++;});

3、执行完毕后,$scalarCount值为6,即全部字符串元素个数。

4、该方法不依赖数组结构深度,对任意深度嵌套均有效,且仅统计终端标量。

五、使用json_encode 与 substr_count 粗略估算嵌套层级

通过 编码 json字符串后统计左方括号数量,可间接推断数组嵌套深度。该方法不用于精确计数,但可快速识别是否为二维或更高维结构。

1、将数组转为 JSON:$json = json_encode($arr);

2、统计左方括号出现次数:$depth = substr_count($json, '[');

3、对示例数组,$depth返回值为4(外层 1 个 + 内层 3 个),表明至少存在两层嵌套。

4、注意该值包含所有[符号,包括字符串中可能出现的误匹配,仅作辅助判断。

以上就是

站长
版权声明:本站原创文章,由 站长 2025-12-15发表,共计1583字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
1a44ec70fbfb7ca70432d56d3e5ef742
text=ZqhQzanResources