[英]using array_search for multi dimensional array
在一维数组中使用array_search很简单
$array = array("apple", "banana", "cherry");
$searchValue = "cherry";
$key = array_search($searchValue, $array);
echo $key;
但是多维数组呢?
#RaceRecord
[CarID] [ColorID] [Position]
[0] 1 1 3
[1] 2 1 1
[2] 3 2 4
[3] 4 2 2
[4] 5 3 5
例如,我想获取位置为1的汽车的索引。我该怎么做?
在PHP 5.5.5及更高版本中,您可以尝试此操作
$array_subjected_to_search =array(
array(
'name' => 'flash',
'type' => 'hero'
),
array(
'name' => 'zoom',
'type' => 'villian'
),
array(
'name' => 'snart',
'type' => 'antihero'
)
);
$key = array_search('snart', array_column($array_subjected_to_search, 'name'));
var_dump($array_subjected_to_search[$key]);
输出:
array(2) { ["name"]=> string(5) "snart" ["type"]=> string(8) "antihero" }
工作示例: http : //sandbox.onlinephpfunctions.com/code/19385da11fe0614ef5f84f58b6dae80bd216fc01
有关array_column的文档可在此处找到
function find_car_with_position($cars, $position) {
foreach($cars as $index => $car) {
if($car['Position'] == $position) return $index;
}
return FALSE;
}
你可以试试这个
array_search(1, array_column($cars, 'position'));
万里一线!
$index = array_keys(array_filter($array, function($item){ return $item['property'] === 'whatever';}))[0];
让我们更清楚一点:
array_filter(
$array,
function ($item) {
return $item['property'] === 'whatever';
}
);
返回一个数组,其中包含所有满足回调条件的元素,同时保留其原始数组键。 我们基本上需要该数组第一个元素的键。
为此,我们将结果包装在array_keys()
调用中并获取它的第一个元素。 此特定示例假设存在至少一个匹配元素,因此为了安全起见,可能需要进行额外检查。
我基本上是“重新创建”了underscore.js的findWhere方法。
功能:
function findWhere($array, $matching) {
foreach ($array as $item) {
$is_match = true;
foreach ($matching as $key => $value) {
if (is_object($item)) {
if (! isset($item->$key)) {
$is_match = false;
break;
}
} else {
if (! isset($item[$key])) {
$is_match = false;
break;
}
}
if (is_object($item)) {
if ($item->$key != $value) {
$is_match = false;
break;
}
} else {
if ($item[$key] != $value) {
$is_match = false;
break;
}
}
}
if ($is_match) {
return $item;
}
}
return false;
}
例:
$cars = array(
array('id' => 1, 'name' => 'Toyota'),
array('id' => 2, 'name' => 'Ford')
);
$car = findWhere($cars, array('id' => 1));
要么
$car = findWhere($cars, array(
'id' => 1,
'name' => 'Toyota'
));
我相信这种方法可以轻松降低LOC。 我有点累 :P
实际上,所有数组函数都是针对单维数组而设计的。您始终需要记住,将其应用于单维数组。
function find_car_with_position($cars, $position) {
for($i=0;$i<count($cars);$i++){
if(array_search($search_val, $cars[$i]) === false){
// if value not found in array.....
}
else{
// if value is found in array....
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.