Python获取特定元素的元素值

时间:2016-08-23 03:24:02

标签: python xml elementtree

我正在尝试解析下面的XML文件,但很难获得特定的元素值。我正在尝试指定元素&#39; Item_No_2&#39;获取相关值<v>2222222222</v>但无法使用get.element(&#39; Item_No_2&#39;)执行此操作。我是否错误地使用了get.element值?

XML文件:

<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="Data.xsl"?>
<abc>
  <md>
    <mi>
      <datetime>20160822020003</datetime>
      <period>3600</period>
      <it>Item_No_1</it>
      <it>Item_No_2</it>
      <it>Item_No_3</it>
      <it>Item_No_4</it>
      <it>Item_No_5</it>
      <it>Item_No_6</it>
      <it>Item_No_7</it>
      <ovalue>
        <v>1111111111</v>
        <v>2222222222</v>
        <v>3333333333</v>
        <v>4444444444</v>
        <v>5555555555</v>
        <v>6666666666</v>
        <v>7777777777</v>
      </ovalue>
    </mi>
  </md>
</abc>

我的代码:

from xml.etree.ElementTree import parse

doc = parse('test.xml').getroot()

for element in doc.findall('md/mi/'):
    print(element.text)

for element in doc.findall('md/mi/ovalue/'):
    print(element.text)

当前输出单独获取它们但我似乎无法理解如何调用特定元素值。

输出:

20160822020003
3600
Item_No_1
Item_No_2
Item_No_3
Item_No_4
Item_No_5
Item_No_6
Item_No_7


1111111111
2222222222
3333333333
4444444444
5555555555
6666666666
7777777777

试过这个但是没有用:

for element in doc.findall('md/mi/ovalue/'):
    print(element.get('Item_No_1'))

1 个答案:

答案 0 :(得分:2)

Item_No_1找到的元素没有doc.findall('md/mi/ovalue/')

我认为您可能尝试做的是获取两个列表

items = [e.text for e in doc.findall('md/mi/it')]
values = [e.text for e in doc.findall('md/mi/ovalue/v')]

然后从'Item_No_1'找到字符串items的索引,然后使用该编号索引到values

或者,将zip两个列表放在一起,并检查何时找到一个元素。

for item,value in zip(doc.findall('md/mi/it'), doc.findall('md/mi/ovalue/v')):
    if item.text == 'Item_No_1':
        print(value.text)

可能有更好的方法,但这些是第一种想到的方式