为了账号安全,请及时绑定邮箱和手机立即绑定

用Python中的命名空间通过‘ElementTree’解析XML

用Python中的命名空间通过‘ElementTree’解析XML

子衿沉夜 2019-06-05 16:23:44
用Python中的命名空间通过‘ElementTree’解析XML我有以下XML,我想使用Python的ElementTree:<rdf:RDF xml:base="http://dbpedia.org/ontology/"     xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"     xmlns:owl="http://www.w3.org/2002/07/owl#"     xmlns:xsd="http://www.w3.org/2001/XMLSchema#"     xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"     xmlns="http://dbpedia.org/ontology/">     <owl:Class rdf:about="http://dbpedia.org/ontology/BasketballLeague">         <rdfs:label xml:lang="en">basketball league</rdfs:label>         <rdfs:comment xml:lang="en">           a group of sports teams that compete against each other           in Basketball        </rdfs:comment>     </owl:Class></rdf:RDF>我想找到所有owl:Class标记,然后提取所有rdfs:label它们里面的例子。我使用以下代码:tree = ET.parse("filename")root = tree.getroot()root.findall('owl:Class')由于名称空间,我得到以下错误。SyntaxError: prefix 'owl' not found in prefix map我试着在http://effbot.org/zone/element-namespaces.htm但我仍然无法做到这一点,因为上面的XML有多个嵌套的名称空间。请告诉我如何更改代码以查找所有owl:Class标签。
查看完整描述

3 回答

?
qq_花开花谢_0

TA贡献1835条经验 获得超7个赞

下面是如何使用lxml实现此操作,而不必对名称空间进行硬编码或扫描它们的文本(正如Martijn Pieters所提到的):

from lxml import etree
tree = etree.parse("filename")root = tree.getroot()root.findall('owl:Class', root.nsmap)


查看完整回答
反对 回复 2019-06-05
  • 3 回答
  • 0 关注
  • 2301 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信