【问题标题】:Recursively traversing through XML nodes in perl XML::LibXML递归遍历perl XML::LibXML中的XML节点
【发布时间】:2014-03-24 07:58:43
【问题描述】:

我有一个 xml,我需要解析 xml 并遍历到最后一个孩子,XML 将动态生成,所以我不知道 XML 的深度,我可以遍历 xml 直到它的最后一个孩子和兄弟姐妹如果有的话。请帮忙解决这个问题:

我的代码 sn-p 是:

            foreach my $childNodes ($root->findnodes('/'))
            {
                print $childNodes->nodePath;
                print "\n";
                if($childNodes->hasChildNodes)
                {
                    foreach my $gChildNode ($camelid->childNodes)
                    {
                      print $gChildNode->nodePath;
                      print "\n";
                    }
             }

这会打印节点直到深度 2,但如果深度为 3,我的意思是根有一个孩子,而孩子我的代码会打印它,但如果这里有另一个孩子,代码将不会打印并且无法猜测..怎么能我找到了这个。

提前致谢。

【问题讨论】:

  • 答案就在你的标题中:你需要递归。

标签: xml perl xml-libxml


【解决方案1】:

只需包装代码以在函数中处理节点并递归调用它。带有一些额外 cmets 的示例:

sub process_node {
    my $node = shift;

    print $node->nodePath, "\n";

    # No need to check hasChildNodes. If there aren't any
    # children, childNodes will return an empty array.
    for my $child ($node->childNodes) {
        # Call process_node recursively.
        process_node($child);
    }
}

# documentElement is more straight-forward than findnodes('/').
process_node($root->documentElement);

【讨论】:

  • 请找到我的代码 sn-p 作为我问题的答案...谢谢您的回复..
  • @SriSri StackOverflow 不像带有线程的讨论论坛那样工作。如果您需要更多帮助,您应该提出一个新问题。
  • 非常感谢您的更新..我认为其他方式..将开始新的讨论。
猜你喜欢
  • 1970-01-01
  • 2011-08-19
  • 2014-07-03
  • 2020-08-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多