我的数组看起来像这样:
$arr = Array();
$arr[] = Array("foo", "bar");
$arr[] = Array("test", "hello");
现在我想检查是否$arr
包含一个包含foo
在第一个位置的数组。
是否有任何功能,或者我应该循环$arr
并搜索其中的每个数组?
我的数组看起来像这样:
$arr = Array();
$arr[] = Array("foo", "bar");
$arr[] = Array("test", "hello");
现在我想检查是否$arr
包含一个包含foo
在第一个位置的数组。
是否有任何功能,或者我应该循环$arr
并搜索其中的每个数组?
这样做的一个很好的小方法是使用array_reduce
- 通过传入一个函数来总结值 1 如果foo
找到,则 0 如果没有:
$foo_found = array_reduce(
$arr,
function ($num_of_hits, $item, $search_for = 'foo') {
$num_of_hits += $item[0] === $search_for ? 1 : 0;
return $num_of_hits;
}
);
$xyz_found = array_reduce(
$arr,
function ($num_of_hits, $item, $search_for = 'xyz') {
$num_of_hits += $item[0] === $search_for ? 1 : 0;
return $num_of_hits;
}
);
var_dump($foo_found, $xyz_found);
返回 1 和 0,原因foo
找到一次,xyz
找到零次。
我认为有几种不同的方法可以做到这一点。请检查以下内容
$arr_zero = Array();
$arr_zero[] = Array("foo", "bar");
$arr_zero[] = Array("test", "hello");
$arr_zero[] = Array("nal", "rob");
$array_one = array_shift(array_values($arr_zero));
$element = array_shift(array_values($array_one));
if($element=='foo');
echo "its ok";
或者
$arr_zero = Array();
$arr_zero[] = Array("foo", "bar");
$arr_zero[] = Array("test", "hello");
$array_one = array_shift(array_values($arr_zero));
$element = reset($array_one); // First Element's Value
if($element=='foo');
echo "its ok";
或者
$arr_zero = Array();
$arr_zero[] = Array("foo", "bar");
$arr_one = $arr_zero[key($arr_zero)];
echo $arr_one[key($arr_one)];
获取密钥
$arr_zero = Array();
$arr_zero[] = Array("foo", "bar");
$arr_zero[] = Array("test", "hello");
$array_one = array_shift(array_values($arr_zero));
echo key($array_one); // First Element's Key
你的数组:
$arr = Array();
$arr[] = Array("foo", "bar");
$arr[] = Array("foo", "hello");
我的解决方案:
echo search_in_array("foo",$arr); // This will show you the number of items found
function search_in_array($value, $arr){
$num = 0;
for ($i = 0; $i < count($arr); ) {
if($arr[$i][0] == $value) {
$num++;
}
$i++;
}
return $num ;
}