[英]Get the value from the n-1 node with lxml.etree
我有這個etree:
<root>
<test>
<criteria nom="DR">
<abbr>DR</abbr>
<value>0.123456</value>
</criteria>
<criteria nom="MOTA">
<abbr>MOTA</abbr>
<value>0.132465</value>
</criteria>
<criteria nom="PFR">
<abbr>PFR</abbr>
<value>0.914375</value>
</criteria>
</test>
<test>
<criteria nom="DR">
<abbr>DR</abbr>
<value>0.655425</value>
</criteria>
<criteria nom="MOTA">
<abbr>MOTA</abbr>
<value>0.766545</value>
</criteria>
<criteria nom="PFR">
<abbr>PFR</abbr>
<value>0.943154</value>
</criteria>
</test>
</root>
我需要一個一個的值
0.655425
0.766545
0.943154
以便將它們與值“ 0.25”進行比較。
- 編輯 -
我已經試圖通過像這樣在主樹中循環來獲取值:
tree = etree.fromstring(the tree above)
root = tree.getroot()
for test in root.findall("test"):
for criteria in test.findall(criteria):
value = criteria.findall("value").text()
但這不起作用。
使用xml模塊 。 並使用enumerate
。
防爆
import xml.etree.ElementTree as ET
tree = ET.fromstring(s)
for i, content in enumerate(tree.findall(".//test")):
if i % 2 != 0:
for val in content.findall("criteria/value"):
print(val.text)
輸出:
0.655425
0.766545
0.943154
使用lxml和XPath :
from lxml import etree
tree = etree.parse(open("so.xml"))
for value in tree.xpath("/root/test[2]/criteria/value"):
print(value.text)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.