ฉันมี 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
แท็กทั้งหมด