检查数组是否是多维的?
- 什么是最有效的方法来检查一个数组是一个平面的原始值数组,或者如果它是一个multidimensional array ?
- 有没有什么办法做到这一点,而不是实际循环一个数组,并在其每个元素上运行
is_array()
?
简短的回答是,如果“第二维度”可能在任何地方,则至less在没有隐含循环的情况下不能做到这一点。 如果它必须在第一个项目中,你会这样做
is_array($arr[0]);
但是,我能find的最有效的一般方法是在数组上使用一个foreach循环,每find一个命中就进行shortcircuiting(至less隐式循环比())的直线更好:
$ more multi.php <?php $a = array(1 => '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
隐式循环,但只要find匹配,我们就不能短路
$ more multi.php <?php $a = array(1 => '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)
使用count()两次; 一次是默认模式,一次是recursion模式。 如果值匹配,则数组不是多维的,因为multidimensional array将具有更高的recursion计数。
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()将recursion计数数组。 这对计算multidimensional array的所有元素特别有用。 count()不会检测到无限recursion。
但是这个方法不检测array(array())
。
对于PHP 4.2.0或更新版本:
function is_multi($array) { return (count($array) != count($array, 1)); }
你可以简单地执行这个:
if (count($myarray) !== count($myarray, COUNT_RECURSIVE)) return true; else return false;
如果可选模式参数设置为COUNT_RECURSIVE
(或1),count()将recursion计数数组。 这对计算multidimensional array的所有元素特别有用。
如果相同,则意味着在任何地方都没有子级别。 方便快捷!
你可以在第一个元素上检查is_array()
,假设如果数组的第一个元素是一个数组,那么其余的都是。
所有伟大的答案…这是我总是使用我的三条线
function isMultiArray($a){ foreach($a as $v) if(is_array($v)) return TRUE; return FALSE; }
我认为这是最直接的方式,它是最先进的:
function is_multidimensional(array $array) { return count($array) !== count($array, COUNT_RECURSIVE); }
这个函数将返回整数个数组维数(从这里被盗)。
function countdim($array) { if (is_array(reset($array))) $return = countdim(reset($array)) + 1; else $return = 1; return $return; }
我想你会发现这个function是最简单,最有效,最快捷的方式。
function isMultiArray($a){ foreach($a as $v) if(is_array($v)) return TRUE; return FALSE; }
你可以像这样testing它:
$a = array(1 => 'a',2 => 'b',3 => array(1,2,3)); $b = array(1 => 'a',2 => 'b'); echo isMultiArray($a) ? 'is multi':'is not multi'; echo '<br />'; echo isMultiArray($b) ? 'is multi':'is not multi';
你也可以这样做一个简单的检查:
$array = array('yo'=>'dream', 'mydear'=> array('anotherYo'=>'dream')); $array1 = array('yo'=>'dream', 'mydear'=> 'not_array'); function is_multi_dimensional($array){ $flag = 0; while(list($k,$value)=each($array)){ if(is_array($value)) $flag = 1; } return $flag; } echo is_multi_dimensional($array); // returns 1 echo is_multi_dimensional($array1); // returns 0
尝试如下
if (count($arrayList) != count($arrayList, COUNT_RECURSIVE)) { echo 'arrayList is multidimensional'; }else{ echo 'arrayList is no multidimensional'; }
我认为这是一个优雅(道具给另一个用户,我不知道他的用户名):
static public function isMulti($array) { $result = array_unique(array_map("gettype",$array)); return count($result) == 1 && array_shift($result) == "array"; }
以上所有方法都太复杂,无法快速推出。 如果一个数组是平的,那么testing第一个元素应该返回一个原始数据,例如int,string等。如果它是多维的,它应该返回一个数组。 通过扩展,你可以使用这个快速和整齐的衬垫。
echo is_array(array_shift($myArray));
如果这返回true,则该数组是多维的。 否则它是平坦的。 需要注意的是,对于数组来说,具有不同的维度是非常罕见的,例如,如果从模型中生成数据,它将始终具有相同types的多维或平面结构,可以通过循环遍历。 如果不是的话,那么你可以自己定制它,这意味着你知道一切都会在哪里,而且不需要编写循环algorithm
除了以前的答案和取决于你想要检查的数组的架构:
function is_multi_array($array=[],$mode='every_key'){ $result = false; if(is_array($array)){ if($mode=='first_key_only'){ if(is_array(array_shift($array))){ $result = true; } } elseif($mode=='every_key'){ $result = true; foreach($array as $key => $value){ if(!is_array($value)){ $result = false; break; } } } elseif($mode=='at_least_one_key'){ if(count($array)!==count($array, COUNT_RECURSIVE)){ $result = true; } } } return $result; }
即使这个工程
is_array(current($array));
如果它是一个单维数组,如果它是一个多维数组。
current将会给你数组的第一个元素,并通过is_array函数检查第一个元素是否是数组。
function isMultiArray(array $value) { return is_array(reset($value)); }
if($array[0]){ //enter your code }
if ( array_key_exists(0,$array) ) { // multidimensional array } else { // not a multidimensional array }
*仅适用于具有数字索引的数组
is_array($arr[key($arr)]);
没有循环,简单而简单。
与关联数组一起工作的不仅仅是数组数组,它不能包含0(就像在前面的例子中,如果数组没有0,会引发一个警告)