Я можу запропонувати declxml .
Повне розкриття: я написав цю бібліотеку, тому що шукав спосіб конвертувати між XML і Python структурами даних без необхідності запису десятків рядків обов'язкового розбору / коду серіалізації за допомогою ElementTree.
За допомогою declxml ви використовуєте процесори, щоб декларативно визначити структуру вашого XML-документа та спосіб відображення між структурами даних XML та Python. Процесори використовуються як для серіалізації та розбору, так і для базового рівня перевірки.
Розбір структур даних Python простий:
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)
Що дає результат:
{'bar': {'foobar': [1, 2]}}
Ви також можете використовувати той самий процесор для серіалізації даних у XML
data = {'bar': {
'foobar': [7, 3, 21, 16, 11]
}}
xml.serialize_to_string(processor, data, indent=' ')
Що дає наступний вихід
<?xml version="1.0" ?>
<foo>
<bar>
<type foobar="7"/>
<type foobar="3"/>
<type foobar="21"/>
<type foobar="16"/>
<type foobar="11"/>
</bar>
</foo>
Якщо ви хочете працювати з об'єктами замість словників, ви можете визначити процесори для перетворення даних і в об'єкти.
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)
Що дає наступний вихід
{'bar': Bar(foobars=[1, 2])}