在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