使用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())
.
使用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())
.
简短的回答是,如果"第二维"可能在任何地方,至少不能隐式循环,你就不能做到这一点.如果它必须在第一项中,你就是这么做的
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)
对于PHP 4.2.0或更高版本:
function is_multi($array) { return (count($array) != count($array, 1)); }
我认为这是最直接的方式,它是最先进的:
function is_multidimensional(array $array) { return count($array) !== count($array, COUNT_RECURSIVE); }
你可以简单地执行这个:
if (count($myarray) !== count($myarray, COUNT_RECURSIVE)) return true; else return false;
如果可选模式参数设置为COUNT_RECURSIVE
(或1),count()将递归计数数组.这对于计算多维数组的所有元素特别有用.
如果它是相同的,意味着任何地方都没有分层.简单快捷!
您可以查看is_array()
第一个元素,假设如果数组的第一个元素是数组,那么其余元素也是如此.