微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在Java中对XML子树进行排序[重复]

如何解决在Java中对XML子树进行排序[重复]

|                                                                                                                   这个问题已经在这里有了答案:                                                      

解决方法

        我会用dom4j完成。 dom4j
Element
提供其子元素的实时列表视图,您可以对其进行排序。使用“ 1”键,您可以修改整个文档:
Document document = DocumentHelper.parseText(someXml);
final Comparator<Element> comparator = new Comparator<Element>() {
    public int compare(Element o1,Element o2) {
        return o1.getName().compareTo(o2.getName());
    }
};
Visitor visitor = new VisitorSupport() {
    @Override
    public void visit(Element node) {
        @SuppressWarnings(\"unchecked\") // dom4j doesn\'t know generics yet
        List<Element> elements = node.elements();
        Collections.sort(elements,comparator);
        super.visit(node);
    }
};
document.accept(visitor);
// now write the document back to a file
没有比这容易的多了。 更新:在尝试使用我自己的解决方案很多之后,我意识到它不能那样工作。
Element.elements()
返回的列表不喜欢
Collections.sort()
,因此您将不得不使用
Element.content()
返回的列表。不幸的是,这意味着您的比较器将不得不处理
Node
,而不是
Element
,如果您混合了内容,这将变得非常混乱。     ,        您已经迈出了第一步,这是要认识到在Java中使用类似DOM的接口进行此类工作极端繁琐。现在,迈出下一步-在XSLT中更加轻松。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。