当我处理用 Python LXML 模块解析的 XML 时(特别是lxml.objectify
,但我认为这没有什么不同),我怎样才能保留 CDATA?
鉴于以下结果:
>>> from lxml import objectify, etree
>>> xml = '''
<Root>
<Child>
<![CDATA[abcd]]>
</Child>
</Root>
'''
>>> parser = objectify.makeparser(strip_cdata=False)
>>> parsed = objectify.XML(xml, parser=parser)
>>> etree.tostring(parsed)
'<Root><Child><![CDATA[abcd]]></Child></Root>'
>>> type(parsed.Child)
<type 'lxml.objectify.StringElement'>
>>> parsed.Child.text
'abcd'
>>> parsed.Child = 'efgh'
>>> etree.tostring(parsed)
'<Root><Child xmlns:py="http://codespeak.net/lxml/objectify/pytype" py:pytype="str">efgh</Child></Root>'
我希望最后一行仍然有<![CDATA[....]>
. 但我看不到任何保存或重建它的方法。尝试访问<Child>
元素的内容会产生一个裸字符串,并且修改该元素的内容会神奇地消失 CDATA 部分。
这样做的正确方法是什么?