繁体   English   中英

Python XML findall返回错误的东西

[英]Python XML findall is returning the wrong thing

我想从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

我有什么想法吗? 我尝试了不同的解决方案,但似乎没有任何工作(从我尝试的事情)。

这里(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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM