![](/img/trans.png)
[英]How to parse XML in python using ElementTree (find content of a tag)
[英]How To Comment Out XML <Tag> using ElementTree
我想注释掉这样的文本:
<name>cranberry</name>
但是,我的脚本返回的输出如下:
<!-- <name>cranberry</name> -->
我的剧本:
import xml.etree.ElementTree as ET
from xml.etree.ElementTree import Comment
tree = ET.parse(r"C:\sample.xml")
root = tree.getroot()
comment = ET.Comment("<name>cranberry</name>")
root.insert(0,comment)
tree.write(r"C:\sample1.xml")
任何意见,将不胜感激。
实际上,Python 2.6中包含的较旧的ElementTree库确实无条件地在注释中进行了XML转义数据:
$ python2.6 -c "from xml.etree import ElementTree as ET; print ET.tostring(ET.Comment('<'))"
<!-- < -->
您有几种选择:
升级到Python 2.7; 它可以正确处理注释序列化:
$python2.7 -c "from xml.etree import ElementTree as ET; print ET.tostring(ET.Comment('<'))" <!--<-->
安装外部ElementTree库。
使用Minidom(不建议使用,DOM API过于冗长):
from xml.dom import minidom doc = minidom.parse(r"C:\\sample.xml") comment = doc.createComment("<name>cranberry</name>") doc.documentElement.appendChild(comment) doc.writexml(r"C:\\sample1.xml")
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.