在php中,如何获取数组\u walk\u recursive第一次出现的值

在php中,如何获取数组\u walk\u recursive第一次出现的值,php,array-walk,Php,Array Walk,我有一个深层多维数组,需要提取特定键的值。我发现array\u walk\u recursive函数将是我的最佳选择。我只需要第一次出现 我的数组看起来像这样-(除了更复杂) 这里的问题是,子模型有一个和三个。此外,数组不一致,因此我必须使用array\u walk\u recursive在其中搜索匹配的键,然后返回该键的值 这是我目前的代码- array_walk_recursive ($array, (function ($item, $key) { $wanted = "submo

我有一个深层多维数组,需要提取特定键的值。我发现
array\u walk\u recursive
函数将是我的最佳选择。我只需要第一次出现

我的数组看起来像这样-(除了更复杂)

这里的问题是,
子模型
有一个和三个。此外,数组不一致,因此我必须使用
array\u walk\u recursive
在其中搜索匹配的键,然后返回该键的值

这是我目前的代码-

array_walk_recursive ($array, (function ($item, $key) {
    $wanted = "submodel";
    if ($key === $wanted) {
        echo ("$key is $item");
    }
}));
上面返回的
子模型为LX子模型为LX

奖金问题
如何搜索多个键并返回每个键的第一个对应值?我想把所有想要的键放在一个数组中,然后做一个foreach循环,但我不太知道如何构造它。我是php新手。

我会首先设置要
null
的值,然后仅在尚未找到它们时保存它们,方法是选中
is_null()
。我还没有测试过这段代码,但它应该是这样的:

$submodel = null;
array_walk_recursive ($array, (function ($item, $key) {
    $wanted = "submodel";
    if ($key === $wanted && is_null($submodel)) {
        echo ("$key is $item");
        $submodel = $item;
    }
}));
array_walk_recursive()的缺点是不允许返回匹配结果,但是在PHP7中,可以使用匿名函数和变量来存储匹配值

$matching = null;
$wanted = "submodel";

array_walk_recursive ($array, function ($item, $key) use ($wanted, $matching) {
    if (($key === $wanted) && is_null($matching)) {
        $matching = $item;
    }
});

由于无法从
array\u walk\u recursive()
提前返回,我建议创建一个函数来查找第一个出现的
$wanted

$arr = [
  'vehicle info' => [
     'one' => ['submodel' => 'LX', 'engine' => '2.3'],
     'two' => ['color' => 'blue', 'year' => '2007', 'wheels' => '4'],
     'three' => ['submodel' => 'LX', 'make' => 'Ford', 'model' => 'F-150', 'offroad' => 'No'],
    ],
];

function find($needle, $haystack, $found = '')
{
    foreach ($haystack as $key => $value) {
        if ($found) {
            break;
        }
        if ($key === $needle) {
            $found = "{$needle} is {$value}";
            break;
        }
        if (is_array($value)) {
            $found = find($needle, $value, $found);
        }
    }
    return $found;
}

$wanted = 'submodel';
$result = find($wanted, $arr);

var_dump($result); // string(14) "submodel is LX"
生活


更新:要搜索多个键,您需要在循环中进行:

$multiple_keys = array('submodel', 'year');

foreach ($multiple_keys as $wanted) {
    var_dump(find($wanted, $arr));
}

// Output:
//    string(14) "submodel is LX"
//    string(12) "year is 2007"
Live

数组\u walk\u recursive()
是调用此任务的适当本机函数。跟踪已在结果数组中声明的键,并确保它们从未被覆盖

代码:()

输出:

array (
  'submodel' => 'submodel is LX',
  'offroad' => 'offroad is No',
)

如果您的应用程序存在性能问题,那么本机函数的吸引力就会降低,因为它总是迭代整个输入数组的结构——即使在遇到所有查找的键之后也是如此。如果您想“提前中断”(短路),那么您需要设计自己的递归函数,当找到所有查找的键时,该函数将返回

代码:()


有趣的问题,虽然有人可能想知道返回值时的含义,因为可能有多个值具有相同的索引?@Code4R7,我看到的方式是每个
vehicle\u info
都有多个相同的键,但它们都有重复的值,所以具体保存哪一个并不重要,只要有人回来。e、 g.
[submodel]=>LX
存在于
[one]
[three]
中,这家伙确实说过“我是php新手”,我想数据库也是如此。我的意思是,这通常是MySQL/MariaDB/PostgreSQL进入画面的地方。@CFraley你能解释更多关于
(除了更复杂的)
?我的意思是,你是说实际的数组是“长”而不是“深”的,还是说它既长又深?如果没有比您发布的内容更深的级别,并且值都在同一个“级别”,那么可以/应该替换
array\u walk\u recursive()
如JoeBlack所说。@mickmackusa数组比这里写的要长得多,也要深得多。这是一个来自cURL post的XML响应。不幸的是,数组的前5个“步骤”并不总是一致的,因此我必须搜索整个数组并深入挖掘,直到找到我要查找的内容。这有意义吗?
$needles = ['submodel', 'offroad'];
$result = [];
array_walk_recursive(
    $array,
    function($value, $key) use ($needles, &$result) {
        if (
            in_array($key, $needles)
            && !isset($result[$key])
        ) {
            $result[$key] = "$key is $value";
        }
    }
);
var_export($result);
array (
  'submodel' => 'submodel is LX',
  'offroad' => 'offroad is No',
)
$soughtKeys = array_flip(['submodel', 'offroad']);

function earlyReturningRecursion(array $array, array $soughtKeys, array &$result = []): array
{
    foreach ($array as $key => $value) {
        if (!array_diff_key($soughtKeys, $result)) {  // check if result is complete
            return $result;
        } elseif (is_array($value)) {
            earlyReturningRecursion($value, $soughtKeys, $result);
        } elseif (isset($soughtKeys[$key]) && !isset($result[$key])) {
            $result[$key] = "$key is $value";
        }
    }
    return $result;
}
var_export(earlyReturningRecursion($array, $soughtKeys));
// same output as the first snippet