コード:
function search($array, $key, $value)
{
$results = array();
if (is_array($array)) {
if (isset($array[$key]) && $array[$key] == $value) {
$results[] = $array;
}
foreach ($array as $subarray) {
$results = array_merge($results, search($subarray, $key, $value));
}
}
return $results;
}
$arr = array(0 => array(id=>1,name=>"cat 1"),
1 => array(id=>2,name=>"cat 2"),
2 => array(id=>3,name=>"cat 1"));
print_r(search($arr, 'name', 'cat 1'));
出力:
Array
(
[0] => Array
(
[id] => 1
[name] => cat 1
)
[1] => Array
(
[id] => 3
[name] => cat 1
)
)
効率が重要な場合は$results
、次のように配列をマージするのではなく、すべての再帰呼び出しが結果を同じ一時配列に格納するように記述できます。
function search($array, $key, $value)
{
$results = array();
search_r($array, $key, $value, $results);
return $results;
}
function search_r($array, $key, $value, &$results)
{
if (!is_array($array)) {
return;
}
if (isset($array[$key]) && $array[$key] == $value) {
$results[] = $array;
}
foreach ($array as $subarray) {
search_r($subarray, $key, $value, $results);
}
}
そこにあるキーは、search_r
値ではなく参照によって4番目のパラメーターを受け取ります。アンパサンド&
は重要です。
FYI:あなたはPHPの古いバージョンを持っているなら、あなたはで参照渡し一部を指定する必要があり、コールをしsearch_r
、その宣言ではなく。つまり、最後の行はになりsearch_r($subarray, $key, $value, &$results)
ます。
$key
配列に存在しない場合、「効率的な」回答エラーは発生し ませんか?それを行う方が良いif (array_key_exists($key, $array) && $array[$key] == $value) {
でしょうか?