我正在尝试创建一个内存中的xml文档,以便root的子节点都需要名称空间。
最终文件看起来应该是这样的:
<Feed>
<FeedEntity Id="0000"
xmlns="http://schemas.example.com/search/query/2010/5/revision">
<FeedRequest locale="en-US" title="<some value>"/>
</FeedEntity>
... another FeedEntity element ...
</Feed>
但是,当我打印出我使用ElementTree lib创建的文档时,它看起来更像是这样:
<Feed>
<ns0:FeedEntity Id="0000"
xmlns:ns0="http://schemas.example.com/search/query/2010/5/revision">
<FeedRequest locale="en-US" title="<some value>"/>
</ns0:FeedEntity>
</Feed>
以下是我创建文档的方式:
counter = 0
namespace = "http://schemas.example.com/search/query/2010/5/revision"
root = Element("Feed")
node_name = "{%s}FeedEntity" % (namespace, );
feed_entity_element = Element(node_name)
feed_entity_element["Id"] = "%04d" % (counter,);
feed_request_element = Element("FeedRequest");
feed_request_element["Culture"] = self.culture;
feed_request_element["Query"] = address;
# append each of the elements to the xml document
feed_entity_element.append(feed_request_element);
root.append(feed_entity_element);
str_data = ET.tostring(root)
print str_data
如何删除最终XML中的“ns0”部分,使其看起来更像上面提到的第一个示例?
答案 0 :(得分:5)
使用xml.etree
,您无法获得第一个示例中的确切输出,但您可以使用(全局)register_namespace()函数来使用比“ns0”更好的前缀。例如:ET.register_namespace('rev', 'http://schemas.example.com/search/query/2010/5/revision')
将确保输出看起来像rev:FeedEntity
。
然而,(兼容的)lxml库在名称空间前缀和allows you to provide a prefix mapping when creating an element方面更灵活。