python lxml模块对xml属性顺序进行排列_基于属性值用lxml对子元素排序

我试图根据属性值对文档中的一些子元素进行排序,虽然实际排序的函数似乎可以工作,但新排序的元素的拼接似乎不起作用。在from lxml import etree

def getkey(elem):

# Used for sorting elements by @LIN.

# returns a tuple of ints from the exploded @LIN value

# '1.0' -> (1,0)

# '1.0.1' -> (1,0,1)

return tuple([int(x) for x in elem.get('LIN').split('.')])

xml_str = """

"""

root = etree.fromstring(xml_str)

lines = root.findall("PurchaseOrder/LineItems/Line")

lines[:] = sorted(lines, key=getkey)

res_lines = [x.get('LIN') for x in lines]

print res_lines

print etree.tostring(root, pretty_print=True)

当我执行上面的代码时,我会看到lines列表在打印['1.0', '2.0', '3.0']时没有正确排序。但是,XML树没有更新,因为tostring()打印出以下内容。在

^{pr2}$

我有了如何从http://effbot.org/zone/element-sort.htm排序的想法,它说拼接应该是我更新元素顺序所需的全部内容,但事实并非如此。我意识到lxml与elementtree不是100%兼容的,因此作为一个健全的检查,我用elementtree替换了lxml导入,得到了完全相同的结果。在

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值