Ich könnte declxml vorschlagen .
Vollständige Offenlegung: Ich habe diese Bibliothek geschrieben, weil ich nach einer Möglichkeit gesucht habe, zwischen XML- und Python-Datenstrukturen zu konvertieren, ohne Dutzende von Zeilen imperativen Parsing- / Serialisierungscodes mit ElementTree schreiben zu müssen.
Mit declxml verwenden Sie Prozessoren , um die Struktur Ihres XML-Dokuments deklarativ zu definieren und um zwischen XML- und Python-Datenstrukturen zuzuordnen. Prozessoren werden sowohl für die Serialisierung und Analyse als auch für eine grundlegende Validierungsstufe verwendet.
Das Parsen in Python-Datenstrukturen ist einfach:
import declxml as xml
xml_string = """
<foo>
<bar>
<type foobar="1"/>
<type foobar="2"/>
</bar>
</foo>
"""
processor = xml.dictionary('foo', [
xml.dictionary('bar', [
xml.array(xml.integer('type', attribute='foobar'))
])
])
xml.parse_from_string(processor, xml_string)
Welches erzeugt die Ausgabe:
{'bar': {'foobar': [1, 2]}}
Sie können denselben Prozessor auch zum Serialisieren von Daten in XML verwenden
data = {'bar': {
'foobar': [7, 3, 21, 16, 11]
}}
xml.serialize_to_string(processor, data, indent=' ')
Welches erzeugt die folgende Ausgabe
<?xml version="1.0" ?>
<foo>
<bar>
<type foobar="7"/>
<type foobar="3"/>
<type foobar="21"/>
<type foobar="16"/>
<type foobar="11"/>
</bar>
</foo>
Wenn Sie mit Objekten anstelle von Wörterbüchern arbeiten möchten, können Sie Prozessoren definieren, um Daten auch von und zu Objekten zu transformieren.
import declxml as xml
class Bar:
def __init__(self):
self.foobars = []
def __repr__(self):
return 'Bar(foobars={})'.format(self.foobars)
xml_string = """
<foo>
<bar>
<type foobar="1"/>
<type foobar="2"/>
</bar>
</foo>
"""
processor = xml.dictionary('foo', [
xml.user_object('bar', Bar, [
xml.array(xml.integer('type', attribute='foobar'), alias='foobars')
])
])
xml.parse_from_string(processor, xml_string)
Welches erzeugt die folgende Ausgabe
{'bar': Bar(foobars=[1, 2])}