Как я могу преобразовать XML в объект Python?

len = request.headers["Content-Length"]
data=request.stream.read()

Теперь данные являются телом запроса

36
задан Stevoisiak supports Monica 13 February 2018 в 16:01
поделиться

7 ответов

На это стоит посмотреть lxml.objectify .

xml = """<main>
<object1 attr="name">content</object1>
<object1 attr="foo">contenbar</object1>
<test>me</test>
</main>"""

from lxml import objectify

main = objectify.fromstring(xml)
main.object1[0]             # content
main.object1[1]             # contenbar
main.object1[0].get("attr") # name
main.test                   # me

Или наоборот для создания структур XML:

item = objectify.Element("item")
item.title = "Best of python"
item.price = 17.98
item.price.set("currency", "EUR")

order = objectify.Element("order")
order.append(item)
order.item.quantity = 3
order.price = sum(item.price * item.quantity for item in order.item)

import lxml.etree
print(lxml.etree.tostring(order, pretty_print=True))

Вывод:

<order>
  <item>
    <title>Best of python</title>
    <price currency="EUR">17.98</price>
    <quantity>3</quantity>
  </item>
  <price>53.94</price>
</order>
48
ответ дан Stevoisiak supports Monica 27 November 2019 в 05:54
поделиться

Я рекомендовал это несколько раз сегодня, но пробую Красивый Суп (easy_install BeautifulSoup).

from BeautifulSoup import BeautifulSoup

xml = """
<main>
    <object attr="name">content</object>
</main>
"""

soup = BeautifulSoup(xml)
# look in the main node for object's with attr=name, optionally look up attrs with regex
my_objects = soup.main.findAll("object", attrs={'attr':'name'})
for my_object in my_objects:
    # this will print a list of the contents of the tag
    print my_object.contents
    # if only text is inside the tag you can use this
    # print tag.string
9
ответ дан Soviut 27 November 2019 в 05:54
поделиться

David Mertz gnosis.xml.objectify, казалось бы, сделал бы это для Вас. Документация немного трудно для прибытия но существует несколько статей IBM о нем, включая этот .

from gnosis.xml import objectify

xml = "<root><nodes><node>node 1</node><node>node 2</node></nodes></root>"
root = objectify.make_instance(xml)

print root.nodes.node[0].PCDATA # node 1
print root.nodes.node[1].PCDATA # node 2

Создание xml от объектов таким образом является другим разговором, все же.

4
ответ дан Ryan Ginstrom 27 November 2019 в 05:54
поделиться
1
ответ дан Superdumbell 27 November 2019 в 05:54
поделиться
#@Stephen: 
#"can't hardcode the element names, so I need to collect them 
#at parse and use them somehow as the object names."

#I don't think thats possible. Instead you can do this. 
#this will help you getting any object with a required name.

import BeautifulSoup


class Coll(object):
    """A class which can hold your Foo clas objects 
    and retrieve them easily when you want
    abstracting the storage and retrieval logic
    """
    def __init__(self):
        self.foos={}        

    def add(self, fooobj):
        self.foos[fooobj.name]=fooobj

    def get(self, name):
        return self.foos[name]

class Foo(object):
    """The required class
    """
    def __init__(self, name, attr1=None, attr2=None):
        self.name=name
        self.attr1=attr1
        self.attr2=attr2

s="""<main>
         <object name="somename">
             <attr name="attr1">value1</attr>
             <attr name="attr2">value2</attr>
         </object>
         <object name="someothername">
             <attr name="attr1">value3</attr>
             <attr name="attr2">value4</attr>
         </object>
     </main>
"""

#

soup=BeautifulSoup.BeautifulSoup(s)


bars=Coll()
for each in soup.findAll('object'):
    bar=Foo(each['name'])
    attrs=each.findAll('attr')
    for attr in attrs:
        setattr(bar, attr['name'], attr.renderContents())
    bars.add(bar)


#retrieve objects by name
print bars.get('somename').__dict__

print '\n\n', bars.get('someothername').__dict__

произвел

{'attr2': 'value2', 'name': u'somename', 'attr1': 'value1'}


{'attr2': 'value4', 'name': u'someothername', 'attr1': 'value3'}
1
ответ дан JV. 27 November 2019 в 05:54
поделиться

Существует три общих синтаксических анализатора XML для Python: xml.dom.minidom, elementree, и BeautifulSoup.

IMO, BeautifulSoup является безусловно лучшим.

http://www.crummy.com/software/BeautifulSoup/

0
ответ дан user26294 27 November 2019 в 05:54
поделиться

Если гугление вокруг для генератора кода не работает, Вы могли записать свое собственное, которое использует XML в качестве входа и выходных объектов на Вашем предпочтительном языке.

Это не ужасно трудно, однако три процесса шага Синтаксического анализа XML, Генерируйте Код, Компилируйте/Выполняйте Сценарий, делает создание, отлаживающее немного тяжелее.

-1
ответ дан Alan 27 November 2019 в 05:54
поделиться
Другие вопросы по тегам:

Похожие вопросы: