比如对下面的xml,
用python(elementTree)进行解析然后输出,会得到如下的文件:
就是自动的把属性按照属性的名称来排序了,这样的处理方式不是我希望得到的,
不知道能不能:
1 自行指定的顺序来排序属性,然后写入文件
2 按照文件读取时候的属性写入文件
希望大家能够帮我解决下:可以用Java,Python或者Ruby等语言来解决(不要c#和c++),如果引用到了第三方的类库,希望能指出来。
十分感谢热心人的帮助。。。!!!
问题补充:
xrb2008 写道
1 自行指定的顺序来排序属性,然后写入文件
2 按照文件读取时候的属性写入文件
这两条能说清楚些吗?或者你解析完之后,放到一个集合中再排序不行吗,非要在解析的时候排序,而不能在解析后排序?
2 按照文件读取时候的属性写入文件
这两条能说清楚些吗?或者你解析完之后,放到一个集合中再排序不行吗,非要在解析的时候排序,而不能在解析后排序?
是在解析后排序,可是我不知道怎么排序的。比如上面的文件,我想对<student>节点增加一个class属性:
from xml.etree.ElementTree import ElementTree
def setClass(file):
tree = ElementTree()
tree.parse(file)
students = tree.findall('//student')
for student in students:
field.set("class", "class1")
tree.write(file, 'utf-8')
得到的文件会是:
<class>
<student class="class1" id="12" name="alan"></student>
<student class="class1" id="12" name="rose"></student>
<student class="class1" id="15" name="john"></student>
</class>
我想按照指定的顺序对属性进行排序,
比如:name->id->class
<student name="alan" id="12" class="class1"></student>
而不是按照字符的顺序来排列
问题补充:
xrb2008 写道
你是把一个xml解析后再生成一个同样的xml?还是中间要做什么操作再生成xml?
当然是要做操所后生成不一样的文件了,要是生成同样的xml那我解析完不写入,或者直接copy就好了。~ ~