Python XML findall返回错误的东西

时间:2019-06-14 21:04:48

标签: python xml parent-child findall

我想从xml文件中读取数据,但它未返回正确的内容。 我只得到第一个子节点,而不是所有子节点

XML看起来像这样:

<?xml version="1.0" encoding="UTF-8" ?>
<medicalData>
        <pacijent>         #patient1
            <lbo>12345678901</lbo>
            <ime>bob</ime>
            <prezime>smith</prezime>
            <datumRodj>13.10.1954.</datumRodj>
            <pregledi>nema</pregledi>
        </pacijent>
        <pacijent>          #patient2
            <lbo>22345678901</lbo>
            <ime>bobert</ime>
            <prezime>smith</prezime>
            <datumRodj>30.03.2003</datumRodj>
            <pregledi>nema</pregledi>
        </pacijent>

        <lekar>
            <id>111</id>
            <ime>john</ime>
            <prezime>doe</prezime>
            <spacijalizacija>aaa</spacijalizacija>
        </lekar>
</medicalData>

在这里,如果我搜索类似的患者:

d = etree.parse("pacijent.xml")
listaPodataka = d.getroot()
pacijenti = {}
p = []
for podatak in listaPodataka.findall('pacijent'):
      p.append(podatak)
      for pacijent in p:
      lbo=pacijent[0].text
      ime = pacijent[1].text
      prezime = pacijent[2].text
      datumRodjenja = pacijent[3].text
      pregledi=pacijent[4].text


      pacijenti[lbo]=Pacijent(lbo,ime,prezime,datumRodjenja,pregledi)
return pacijenti

它将返回患者1但不返回患者2

任何想法我在做什么错?我尝试了不同的解决方案,但似乎没有任何效果(根据我尝试过的东西)。

1 个答案:

答案 0 :(得分:0)

此处(56605102.xml是从您的帖子中获取的XML)

import xml.etree.ElementTree as ET

root = ET.parse("56605102.xml")

for pacijent in root.findall('pacijent'):
    print(pacijent)
    for child in pacijent:
        print('\t' + child.tag + ':' + child.text)

输出

<Element 'pacijent' at 0x108d70d68>
    lbo:12345678901
    ime:bob
    prezime:smith
    datumRodj:13.10.1954.
    pregledi:nema
<Element 'pacijent' at 0x108f50868>
    lbo:22345678901
    ime:bobert
    prezime:smith
    datumRodj:30.03.2003
    pregledi:nema