使用键和值对搜索多维数组

时间:2017-04-12 13:35:41

标签: php arrays function multidimensional-array

我有以下多维数组来构建动态菜单:

[
    "3gnitjUdm6" => [
        "name" => "Overview",
        "slug" => "overview",
        "priority" => 1,
        "pages" => [
            "i3OQlLqgqO" => [
                "name" => "Dashboard",
                "url" => "",
                "priority" => 2,
                "subpages" => [],
            ],
            "izma1tvjGd" => [
                "name" => "Settings",
                "url" => "/settings",
                "priority" => 4,
                "subpages" => [],
            ]
        ]
    ],
    "IcSujiIx9A" => [
        "name" => "Content",
        "slug" => "content",
        "priority" => 5,
        "pages" => [
            "3KJdhtCRuI" => [
                "name" => "Users",
                "url" => "/users",
                "priority" => 2,
                "subpages" => [],
            ],
            "M3zw9hq6rW" => [
                "name" => "Pets",
                "url" => "/pets",
                "priority" => 4,
                "subpages" => [],
            ],
        ],
    ],
]

每个部分都包含一个页面数组,每个页面都可以包含一个子页面数组。我需要能够搜索这个数组,以使用键和值对找到该部分的键。

private function _find_section($key, $value) {
    foreach($this->menu as $section_key => $section) {
        if(is_array($section[$key])) {
            foreach($section[$key] as $sub_key => $sub) {
                if($sub_key === $value) {
                    return $section_key;
                }
            }
        } elseif(is_string($section[$key])) {
            if($section[$key] === $value) {
                return $section_key;
            }
        } else {
            return false;
        }
    }
}

运行以下代码:

_find_section('name', 'Content')

始终返回false。

2 个答案:

答案 0 :(得分:0)

您可能想要尝试执行递归函数并放弃硬编码foreach()循环,然后您可以使用此方法轻松搜索阵列的多个级别:

function recurseFind($array,$findK,$findV,$last=false)
    {
        if(is_object($array))
            $array  =   (array) $array;

        foreach($array as $key => $value) {
            if($key == $findK && $value == $findV)
                return $last;

            if(is_array($value))
                $doFind =   recurseFind($value,$findK,$findV,$key);

            if(!empty($doFind))
                return $doFind;
        }
    }

print_r(recurseFind($arr,'name','Dashboard'));

给你:

i3OQlLqgqO

答案 1 :(得分:0)

function flatten(array $collection, array $nested_keys = []) {
    $output = [];
    foreach ($collection as $key => $value) {
        foreach ($nested_keys as $nested_key) {
            if (isset($value[$nested_key]) && is_array($value[$nested_key])) {
                $output = array_merge($output, flatten($value[$nested_key], [$nested_key]));
            }
        }
        $output[$key] = $value;
    }

    return $output;
}

function column(array $collection, string $key) {
    return array_combine(
        array_keys($collection),
        array_map(function ($row) use ($key) { return $row[$key]; }, $collection)
    );
}

function find_section(array $menu, string $key, string $value) {
    $set = column(flatten($menu, ['pages', 'subpages']), $key);

    return array_search($value, $set);
}

var_dump(find_section($menu, 'name', 'Dashboard')); // string(10) "i3OQlLqgqO"