根据多维 PHP 数组中的键值对查找子数组
遍历多维数组时,基于键值对查找特定子数组可能具有挑战性在键值对上。但是,有一种有效的方法可以递归地执行此操作,无论数组的深度如何。
函数实现:
让我们创建一个函数来搜索满足指定条件的子数组:
function search($array, $key, $value) { $results = array(); if (is_array($array)) { // Check if the current subarray matches if (isset($array[$key]) && $array[$key] == $value) { $results[] = $array; } // Recursively search inner subarrays 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"));
我们可以搜索具有键“name”和值“cat”的子数组1':
$found = search($arr, 'name', 'cat 1'); print_r($found);
输出:
Array ( [0] => Array ( [id] => 1 [name] => cat 1 ) [1] => Array ( [id] => 3 [name] => cat 1 ) )
效率考虑因素:
为了提高效率,特别是当处理大型数组时,可以通过避免数组合并来优化该函数。相反,它可以将递归调用的结果存储在临时数组中:
function search_optimized($array, $key, $value) { $results = []; 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); } }
通过引用传递结果数组,函数可以有效地构建最终结果。
以上是如何根据多维PHP数组中的键值对高效查找子数组?的详细内容。更多信息请关注PHP中文网其他相关文章!