递归合并两个数组并保留键

问题描述 投票:0回答:2

我无法让此代码运行:

$paths = ['2014/', '2014/04/', '2015/'];
$tree = array();
    foreach ($paths as $path) {
        $dir_exploded = explode("/", $path);
        array_pop($dir_exploded);

        $tmp = array();
        for ($i = count($dir_exploded) - 1; $i >= 0; $i--) {
            if ($i == count($dir_exploded) - 1) {
                $children = array();
            } else {
                $children = array($tmp);
            }
            $tmp = array('text' => $dir_exploded[$i], 'children' => $children);
        }

        $tree = array_replace_recursive($tree, $tmp);
    }
echo(json_encode(array(array('text' => '/', 'children' => array($tree)))));

我得到:

[
    {
        "text": "/",
        "children": [
            {
                "text": "2015",
                "children": [
                    {
                        "text": "04",
                        "children": []
                    }
                ]
            }
        ]
    }
]

所以 2014 年已经被这 2 个数组的合并删除了。我想要得到:

[
    {
        "text": "/",
        "children": [
            {
                "text": "2014",
                "children": [
                    {
                        "text": "04",
                        "children": []
                    }
                ]
            },{
                "text": "2015",
                "children": []
            }
        ]
    }
]

至少我想使用 json_encode 通过 json 发送这棵树,或者如果你知道的话有更好的方法。

php arrays recursion merge
2个回答
1
投票

试试这个代码,我改变了你的一些代码并添加了一些额外的路径。

$paths = array('2014/', '2014/04/','2014/03/','2015/');
$new_tree = $temp_new_tree =  array();
foreach ($paths as $path)
{
    $dir_exploded = explode("/", $path);
    array_pop($dir_exploded);

    $temp_new_tree = (!empty($new_tree)) ? $new_tree : array();
    $tmp = $tree = array();
    for ($i = count($dir_exploded) - 1; $i >= 0; $i--)
    {
        if ($i == count($dir_exploded) - 1) {
            $children = array();
        } else {
            $children = array($tmp);
        }
        $tmp = array('text' => $dir_exploded[$i], 'children' => $children);
    }

    $tree = array_replace_recursive($tree, $tmp);

    $new_tree[$dir_exploded[0]] = $tree;
    if(array_key_exists($dir_exploded[0], $temp_new_tree))
    {
        $new_tree[$dir_exploded[0]]['children'] = array_merge($new_tree[$dir_exploded[0]]['children'], $temp_new_tree[$dir_exploded[0]]['children']);
    }
}
//echo json_encode(array(array('text' => '/', 'children' => array($new_tree))));

$new_tree = array_shift(array_chunk($new_tree, count($new_tree)));
echo json_encode(array(array('text' => '/', 'children' => $new_tree)));

输出将是这样的:--

[
{
    text: "/",
    children: [
        {
            text: "2014",
            children: [
            {
                text: "03",
                children: [ ]
            },
            {
                text: "04",
                children: [ ]
            }
            ]
        },
        {
            text: "2015",
            children: [ ]
        }
    ]
}
]

希望这对您有帮助...


0
投票

您可以使用以下;

<?php
$paths = array('2014/01/02','2014/04/03','2015/07');

$all = array();
foreach ($paths as $path) {
    $temp = explode("/", $path);
    $all[] = tree($temp, 0);

}

var_dump($all);

function tree($arr, $i) {
    if (count($arr) == ($i + 1)) return $arr[$i];
    return array(
            "text" => $arr[$i],
            "children" => tree($arr, $i+1)
        );
}

这是一个工作演示:codepad

© www.soinside.com 2019 - 2024. All rights reserved.