XML mit Namespaces in Python mit ElementTree analysieren
Beim Parsen von XML mit Namespaces in Python mit ElementTree kann es zu einem Fehler kommen, wenn der Namespace Das im XML verwendete Präfix ist nicht explizit definiert.
Problem:
Ein Benutzer hat das folgende XML:
<rdf:RDF ...> <owl:Class> <rdfs:label>...</rdfs:label> ... </owl:Class> </rdf:RDF>
Beim Versuch, das XML mit ElementTree mit dem Standard-Namespace zu analysieren Handhabung, der folgende Fehler ist zurückgegeben:
SyntaxError: prefix 'owl' not found in prefix map
Lösung:
Um diesen Fehler zu beheben, müssen den ElementTree-Methoden, die für das Parsen des XML verantwortlich sind, explizite Namespace-Zuordnungen bereitgestellt werden. Dies kann erreicht werden, indem ein Wörterbuch an das Namespaces-Argument der find()-Methode übergeben wird.
namespaces = {'owl': 'http://www.w3.org/2002/07/owl#'} root = tree.getroot() root.findall('owl:Class', namespaces)
Durch Angabe des Namespaces-Wörterbuchs kann der ElementTree-Parser das Namespace-Präfix („owl“) dem richtigen zuordnen Namespace-URL, sodass die Owl:Class-Knoten erfolgreich abgerufen werden können.
Zusätzlich Überlegungen:
Das obige ist der detaillierte Inhalt vonWie behebe ich den Fehler „Präfix ‚owl' nicht in der Präfixzuordnung gefunden' beim Parsen von Namespace-XML mit Pythons ElementTree?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!