用于保存嵌套的基于XML的数据的数据结构


Data structure to save nested XML based data

我通过curl:获得这种类型的响应

<ArrayOfServerFile>
    <ServerFile>
        ...
        <FileType>Folder</FileType>
        <Identifier>x123</Identifier>
        <Name>Client Templates</Name>
        ...
    </ServerFile>
    <ServerFile>
        ...
        <FileType>XpressDox Template</FileType>
        <Identifier>y456</Identifier>
        <Name>contact-information.xdtpl</Name>
        ...
    </ServerFile>
    ...
</ArrayOfServerFile>

我想把这些信息保存在像data structure这样的树中。

我试过这样的东西:

// Pseudo-code:
function run_procedure()
{
    get XML data via curl
    if FileType == 'Folder'
        save name and other useful data into $tree_like_data_structure
        run_procedure() // recursive call
    else if FileType == 'XpressDox Template'
        save name and other useful data into $tree_like_data_structure
}
var_dump($tree_like_data_structure);

这个想法是这样表示保存的数据:

[0][0] -> data
        [1][0] -> data
        [1][1] -> data
        [1][2] -> [2][0] -> data
                  [2][1] -> data
        [1][3] -> data

我确信这并不难实现,但我已经失去了很多时间而没有成功。任何小费都非常欢迎。谢谢。-

编辑1

我主要关心的是如何获得[depth][element]索引以及如何级别数据(类型、名称、内容等)

编辑2

基本上,这是一个递归编程问题也许通过while语句可以比使用递归函数更容易地完成

尝试将SimpleXML与DOM一起使用来创建数组。

$dom = new DOMDocument;
$dom->loadXML('
<ArrayOfServerFile>
    <ServerFile>
        <FileType>Folder</FileType>
        <Identifier>x123</Identifier>
        <Name>Client Templates</Name>
    </ServerFile>
</ArrayOfServerFile>');
if (!$dom) {
    echo 'Error while parsing the document';
    exit;
}
$s = simplexml_import_dom($dom);
echo $s->ServerFile[0]->FileType;