Elementtree设置属性顺序

Pie*_*one 5 python xml elementtree

我正在尝试编写一个python脚本来标准化通用XML文件,用于配置网站和网站表单.但是要做到这一点,我想维护元素的原始属性排序,或者甚至更好地能够以预定义的方式重新排列它们.目前我尝试过的大多数xml解析器都将属性顺序重写为字母数字.由于这些XML文件是人工读/写和维护的,因此这不太有用.

例如,通用元素在XML中可能如下所示;

<Question QuestionRef="XXXXX" DataType="Integer" Text="Question Text" Availability="Shown" DefaultAnswer="X">
Run Code Online (Sandbox Code Playgroud)

但是,一旦通过elementtree并重新写入新文件,这将更改为:

<Question Availability="Shown" DataType="Integer" DefaultAnswer="X" PartType="X" QuestionRef="XXXXX" Text="Question Text">
Run Code Online (Sandbox Code Playgroud)

由于脚本的目标是标准化大量XML文件以增加同事之间的可读性,并且元素属性中包含的信息具有不同的重要性(例如,QuestionRef非常重要),表明属性需要明智地下令.

我理解python dicts(存储在哪些属性中)自然是无序的,XML规范状态属性排序是无关紧要的,但是这个人的可读性因素是脚本背后的驱动力.

在其他问题(在Stack Overflow上)类似于我已经看到它注意到pxdom可以做到这一点(问题链接:链接),但我找不到任何提及如何在pxdom文档或使用谷歌搜索这样做.那么是否有某种方法来维护属性的顺序或使用当前的XML解析器定义它?最好不要求助于hotpatching :)!

任何人都可以提供的帮助将非常感激:).

nam*_*mit 9

如下所述应用猴子补丁::
ElementTree.py文件中,有一个名为的函数_serialize_xml;
在这个功能; 应用下面提到的补丁;

        ##for k, v in sorted(items):  # remove the sorted here
        for k, v in items:
            if isinstance(k, QName):
                k = k.text
            if isinstance(v, QName):
                v = qnames[v.text]
            else:
                v = _escape_attrib(v, encoding)
            write(" %s=\"%s\"" % (qnames[k], v))
Run Code Online (Sandbox Code Playgroud)

这里; 删除sorted(items)它,items就像我上面做的那样.

另外要禁用基于命名空间的排序(因为在上面的补丁中;当xml属性存在名称空间时,仍然存在排序;否则如果没有名称空间,则上面的工作正常); 所以要做到这一点,{}collections.OrderedDict()from 替换allElementTree.py

现在,您已将所有属性添加到该xml元素中.

在做以上所有之前; 阅读Fredrik Lundh的版权信息ElementTree.py