使用Python在XML文件中查找和更改属性

时间:2018-09-24 21:20:26

标签: python xml parsing

我一直在尝试找出如何使用百分比变化以及在-90 < percentChange < 100范围内更改“希腊缬草”植物的价格。

我可以找到并手动更改名称和数字,只是不知道如何使用百分比更改,并且正在使用Py Charm社区版。代码中的outputt.xml文件是我将更改写入的第二个文件。

我的XML代码段是:

<PLANT>    
    <COMMON>Greek Valerian</COMMON>    
    <BOTANICAL>Polemonium caeruleum</BOTANICAL>    
    <ZONE>Annual</ZONE>
    <LIGHT>Shade</LIGHT>    
    <PRICE>4.36</PRICE>    
    <AVAILABILITY>071499</AVAILABILITY>    
</PLANT>
<PLANT>    
    <COMMON>California Poppy</COMMON>    
    <BOTANICAL>Eschscholzia californica</BOTANICAL>
    <ZONE>Annual</ZONE>    
    <LIGHT>Sun</LIGHT>   
    <PRICE>7.89</PRICE>    
    <AVAILABILITY>032799</AVAILABILITY>
</PLANT>

到目前为止,我得到的Python3代码是:

import xml.etree.ElementTree as ET

with open('plant_catalog.xml', encoding='latin-1') as f:
  tree = ET.parse(f)
  root = tree.getroot()

  for elem in root.getiterator():
    try:
      elem.text = elem.text.replace('4.36', '5')
    except AttributeError:
      pass    
tree.write('outputt.xml', encoding='latin-1')

有人可以帮我解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

只需将价格更改为

current_price*(1+percentChange/100)

首先找到您感兴趣的植物:

for plant in root.iter('COMMON'):
    if plant.text!='Greek Valerian':
        continue
    else:
        price = None
        for i in range(4):
            price = plant.getnext()
        price.text = str(float(price.text)*(1+percentChange/100))