字符串,树只用逗号分隔到多维php数组

时间:2013-10-06 00:06:07

标签: php arrays string data-structures multidimensional-array

我有一个这样的字符串:

a,,b,c,,d,,,e,f,g,,e,,,,

我想得到一个这样的数组:

Array
(
    [a] => Array
        (
        )

    [b] => Array
        (
            [c] => Array
                (
                )

            [d] => Array
                (
                )

        )

    [e] => Array
        (
            [f] => Array
                (
                    [g] => Array
                        (
                        )

                    [e] => Array
                        (
                        )

                )

        )

)

逻辑是:在第一个逗号打开项目后,第二个将关闭该项目,两个逗号之间的所有内容都是其子项。

我做了这个功能:

function source() {
    global $get;
    $items = array();
    $item = true;
    while ($item) {
        $pieces = explode(',', $get, 2);
        if (!empty($pieces[1])) $get = $pieces[1];
        $item = $pieces[0];
        if ($item) $items[$item] = source();
    }
    return $items;
}
$get = 'a,,b,c,,d,,,e,f,g,,e,,,,';
print_r (source());

我仍然遇到一些问题,比如如果字符串以item加上逗号或没有逗号结束,我会得到无限循环。我知道我可以检查是否有足够的逗号并在调用函数之前添加它们,但我不喜欢我的函数。我知道有人比我好。所以我问:

将字符串(树,仅用逗号分隔)转换为多维数组()的最佳解决方案是什么?

P.S。我不确定这是否是最好的询问方式。

1 个答案:

答案 0 :(得分:3)

function parse_tree($str) {
    $base_arr = array();
    $arr = &$base_arr;
    $stack = array();
    foreach (explode(',', $str) as $char) {
        if ($char !== '') {
            $arr[$char] = array();
            $stack[] = &$arr;
            $arr = &$arr[$char];
        } elseif ($stack && $char === '') {
            $tmp = array_slice($stack, -1, 1);
            $arr = &$tmp[0];
            array_pop($stack);
        }
    }
    return $base_arr;
}

在键盘上工作得很好:http://codepad.org/PwKFfQfD