我有一个包含数组的数组。
$a = array ( 0 => array ( 'value' => 'America', ), 1 => array ( 'value' => 'England', ), )
如何检查数组中是否存在“America”? America数组可以是任何键,并且可能有任意数量的子数组,因此请提供通用解决方案。
在php手册上搜索后我发现in_array只适用于顶层。所以像in_array("America", $a)
这样的解决方案将无法工作。
谢谢。
我有一个包含数组的数组。
$a = array ( 0 => array ( 'value' => 'America', ), 1 => array ( 'value' => 'England', ), )
如何检查数组中是否存在“America”? America数组可以是任何键,并且可能有任意数量的子数组,因此请提供通用解决方案。
在php手册上搜索后我发现in_array只适用于顶层。所以像in_array("America", $a)
这样的解决方案将无法工作。
谢谢。
一个通用的解决方案是:
function deep_in_array($needle, $haystack) {
if(in_array($needle, $haystack)) {
return true;
}
foreach($haystack as $element) {
if(is_array($element) && deep_in_array($needle, $element))
return true;
}
return false;
}
我选择使用in_array
和循环的原因是:在我检查数组结构的更深层级之前,我要确保搜索的值不在当前层级中。这样,我希望这段代码比进行某种深度优先搜索方法更快。
function in_2d_array($needle, $haystack) {
foreach($haystack as $element) {
if(in_array($needle, $element))
return true;
}
return false;
}
if(is_array...)
后面的return
存在问题。你不能为每个元素都执行一次返回操作。相反,只有当调用deep_in_array
返回true时才应该返回。 - middusPHP没有原生的array_search_recursive()
函数,但是你可以自定义一个:
function array_search_recursive($needle, $haystack) {
foreach ($haystack as $value) {
if (is_array($value) && array_search_recursive($needle, $value)) return true;
else if ($value == $needle) return true;
}
return false;
}
虽未经测试,但您应该能够理解。
in_array("America", array_column($a, 'value'))
function search($a,$searchval){ //$a - array; $searchval - search value;
if(is_array($a)) {
foreach($a as $val){
if(is_array($val))
if(in_array($searchval,$val)) return true;
}
}
else return false;
}
search($a, 'America'); //function call