php怎么判断二维数组长度_PHP判断二维数组长度的方法

看不見的法師
发布: 2025-12-21 22:57:07
原创
771人浏览过
PHP中获取二维数组长度有四种方法:一、用count()得子数组数量;二、count()配COUNT_RECURSIVE再减子数组数得所有标量元素总数;三、遍历取各子数组count()最大值得最长列数;四、array_keys()结合array_filter()排除空数组/null后count()得有效子数组数。

php怎么判断二维数组长度_php判断二维数组长度的方法

如果您需要获取PHP中二维数组的长度,即统计其包含的一维子数组的数量,可以通过内置函数实现。以下是几种不同的方法:

一、使用count()函数计算外层数组长度

count()函数默认统计数组第一维度的元素个数,适用于获取二维数组中子数组的数量。该函数不递归统计内部元素,因此可直接用于获取“行数”。

1、定义一个二维数组,例如:$arr = [[1, 2], [3, 4, 5], [6]];

2、调用count()函数:$length = count($arr);

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

3、输出结果:echo $length; 将显示3,表示该二维数组有3个子数组。

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

当需要获取二维数组中所有标量值(即所有层级的元素)总数量时,可启用COUNT_RECURSIVE模式。该方式会遍历全部嵌套层级并累加所有非数组类型的值。

1、定义相同二维数组:$arr = [[1, 2], [3, 4, 5], [6]];

2、调用带标志的count()函数:$total = count($arr, COUNT_RECURSIVE);

3、减去子数组本身的数量(因COUNT_RECURSIVE会把每个子数组也计为一个元素):$total -= count($arr);

4、最终结果为6,即所有数字元素之和。

三、遍历并校验每个子数组长度后取最大值

若需确认二维数组是否为“规则矩形结构”,或获取最长子数组的长度(即列数),可逐个检查各子数组的count()结果,并记录最大值。

1、初始化变量:$max_col = 0;

AI Word
AI Word

一款强大的 AI 智能内容创作平台,致力于帮助用户高效生成高质量、原创且符合 SEO 规范的各类文章。

AI Word 226
查看详情 AI Word

2、使用foreach遍历外层数组:foreach ($arr as $sub) {

3、判断当前子数组是否为数组类型且非空:if (is_array($sub) && !empty($sub)) {

4、更新最大长度:$max_col = max($max_col, count($sub));

5、闭合条件与循环:}

6、最终$max_col的值即为最长子数组的元素个数,例如对[[1],[2,3,4],[5,6]]返回3

四、使用array_keys()结合count()避免空子数组干扰

当二维数组中存在null、空数组或非数组元素时,直接count()可能产生误判。此时先过滤出有效子数组再统计更可靠。

1、定义含干扰项的数组:$arr = [[1,2], [], null, [3]];

2、提取所有键名:$keys = array_keys($arr);

3、遍历键名并筛选出对应值为非空数组的项:$valid = array_filter($keys, function($k) use ($arr) { return is_array($arr[$k]) && !empty($arr[$k]); });

4、统计有效子数组数量:$count = count($valid);

5、结果为2,排除了空数组和null的影响。

以上就是php怎么判断二维数组长度_PHP判断二维数组长度的方法的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号