比如这样两个个数组 $arr 认为是空的,$brr 认为是有值的。
$arr=array(0=>'', 1=>array(0=>'' ,1=>array(0=>'') ));$brr=array(0=>'', 1=>array(0=>'' ,1=>array(0=>'1') ));
可以这样
$arr = array(0=>'', 1=>array(0=>'' ,1=>array(0=>'') ));var_dump(preg_replace('/[",\[\]]/', '', json_encode($arr)));
可以这样
$arr = array(0=>'', 1=>array(0=>'' ,1=>array(0=>'') ));var_dump(preg_replace('/[",\[\]]/', '', json_encode($arr)));
可能这样要好些
$arr = array(0=>'', 1=>array('a'=>'' ,1=>array(0=>'') ));var_dump(preg_replace('/"\w+":|[",{}\[\]]/', '', json_encode($arr)));
那就怪了,我只执行了两个函数
肯定要比递归要快的多
递归要这样写
$arr = array(0=>'', 1=>array('a'=>'' ,1=>array(0=>'') ));var_dump(foo($arr));function foo($ar) { if(empty($ar)) return true; if(is_array($ar)) { foreach($ar as $v) { if(! foo($v)) return false; } return true; } return flase;}
递归要这样写
$arr = array(0=>'', 1=>array('a'=>'' ,1=>array(0=>'') ));var_dump(foo($arr));function foo($ar) { if(empty($ar)) return true; if(is_array($ar)) { foreach($ar as $v) { if(! foo($v)) return false; } } return flase;}
$arr=array(0=>'',1=>array(0=>'',1=>array(0=>'')));$brr=array(0=>'',1=>array(0=>'',1=>array(0=>'1')));echo test($arr).'<br>';echo test($brr);function test(&$array){ static $r = 0; if(!is_array($array)){ if(empty($array)){ $r=0; }else{ $r=1; } } foreach ($array as $key => $value) { if (is_array($value)) { test($array[$key]); } else { if(empty($value)){ $r=0; }else{ $r=1; } } } return $r;}