当前位置:  开发笔记 > 编程语言 > 正文

检查数组是否是多维的?

如何解决《检查数组是否是多维的?》经验,为你挑选了6个好方法。

使用count()两次; 一次处于默认模式,一次处于递归模式.如果值匹配,则数组不是多维的,因为多维数组将具有更高的递归计数.

if (count($array) == count($array, COUNT_RECURSIVE)) 
{
  echo 'array is not multidimensional';
}
else
{
  echo 'array is multidimensional';
}

mode在PHP 4.2.0中添加了此选项第二个值.来自PHP文档:

如果可选模式参数设置为COUNT_RECURSIVE(或1),则count()将递归计数数组.这对于计算多维数组的所有元素特别有用.count()不检测无限递归.

但是这种方法没有检测到array(array()).



1> 小智..:

使用count()两次; 一次处于默认模式,一次处于递归模式.如果值匹配,则数组不是多维的,因为多维数组将具有更高的递归计数.

if (count($array) == count($array, COUNT_RECURSIVE)) 
{
  echo 'array is not multidimensional';
}
else
{
  echo 'array is multidimensional';
}

mode在PHP 4.2.0中添加了此选项第二个值.来自PHP文档:

如果可选模式参数设置为COUNT_RECURSIVE(或1),则count()将递归计数数组.这对于计算多维数组的所有元素特别有用.count()不检测无限递归.

但是这种方法没有检测到array(array()).


如上所述,这对于具有空数组的元素不起作用

2> Vinko Vrsalo..:

简短的回答是,如果"第二维"可能在任何地方,至少不能隐式循环,你就不能做到这一点.如果它必须在第一项中,你就是这么做的

is_array($arr[0]);

但是,我能找到的最有效的一般方法是在数组上使用foreach循环,每当发现命中时短路(至少隐式循环优于直接for()):

$ more multi.php
 'a',2 => 'b',3 => array(1,2,3));
$b = array(1 => 'a',2 => 'b');
$c = array(1 => 'a',2 => 'b','foo' => array(1,array(2)));

function is_multi($a) {
    $rv = array_filter($a,'is_array');
    if(count($rv)>0) return true;
    return false;
}

function is_multi2($a) {
    foreach ($a as $v) {
        if (is_array($v)) return true;
    }
    return false;
}

function is_multi3($a) {
    $c = count($a);
    for ($i=0;$i<$c;$i++) {
        if (is_array($a[$i])) return true;
    }
    return false;
}
$iters = 500000;
$time = microtime(true);
for ($i = 0; $i < $iters; $i++) {
    is_multi($a);
    is_multi($b);
    is_multi($c);
}
$end = microtime(true);
echo "is_multi  took ".($end-$time)." seconds in $iters times\n";

$time = microtime(true);
for ($i = 0; $i < $iters; $i++) {
    is_multi2($a);
    is_multi2($b);
    is_multi2($c);
}
$end = microtime(true);
echo "is_multi2 took ".($end-$time)." seconds in $iters times\n";
$time = microtime(true);
for ($i = 0; $i < $iters; $i++) {
    is_multi3($a);
    is_multi3($b);
    is_multi3($c);
}
$end = microtime(true);
echo "is_multi3 took ".($end-$time)." seconds in $iters times\n";
?>

$ php multi.php
is_multi  took 7.53565130424 seconds in 500000 times
is_multi2 took 4.56964588165 seconds in 500000 times
is_multi3 took 9.01706600189 seconds in 500000 times

隐式循环,但一旦找到匹配我们就不能短路...

$ more multi.php
 'a',2 => 'b',3 => array(1,2,3));
$b = array(1 => 'a',2 => 'b');

function is_multi($a) {
    $rv = array_filter($a,'is_array');
    if(count($rv)>0) return true;
    return false;
}

var_dump(is_multi($a));
var_dump(is_multi($b));
?>

$ php multi.php
bool(true)
bool(false)


很好,有一点需要注意,我认为你的过滤行应该有array_map("is_array",$ a),而不是使用is_array作为一个裸字.
值得注意的是,如上所述,multi_3仅适用于基于零的非关联数组,索引中没有间隙,这意味着它不能正确地将这些示例中的任何一个标识为多维.

3> scronide..:

对于PHP 4.2.0或更高版本:

function is_multi($array) {
    return (count($array) != count($array, 1));
}



4> Andreas..:

我认为这是最直接的方式,它是最先进的:

function is_multidimensional(array $array) {
    return count($array) !== count($array, COUNT_RECURSIVE);
}



5> Pian0_M4n..:

你可以简单地执行这个:

if (count($myarray) !== count($myarray, COUNT_RECURSIVE)) return true;
else return false;

如果可选模式参数设置为COUNT_RECURSIVE(或1),count()将递归计数数组.这对于计算多维数组的所有元素特别有用.

如果它是相同的,意味着任何地方都没有分层.简单快捷!



6> Greg Hewgill..:

您可以查看is_array()第一个元素,假设如果数组的第一个元素是数组,那么其余元素也是如此.


像这样:`if(is_array(current($ arr))){//是multidimensional}`
推荐阅读
围脖上的博博_771
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有