将元素树的元素插入到现有的xml

时间:2016-08-17 09:37:37

标签: python xml string elementtree

我正在尝试使用元素树找到向这些项条目添加元素的最简单方法。

我将以下XML输出存储在(xmldata)中。我不想把它写到文件中,我只需要添加id,这样我就可以通过将数据与其他数据中的相应id相关联来进一步使用数据。

你看到的地方

     <archived type="bool">False</archived>

就在我想要添加

之上
     <id>555666</id>

列表中的所有项目(所有ID都相同)

        <?xml version="1.0" encoding="UTF-8" ?>
            <root>
                <tasks type="list">
                    <item type="dict">
                        <archived type="bool">False</archived>
                        <budget_spent type="float">0.0</budget_spent>
                        <billable_hours type="float">0.0</billable_hours>
                        <billable type="bool">True</billable>
                        <billable_amount type="float">0.0</billable_amount>
                        <budget_left type="null"/>
                        <over_budget_percentage type="null"/>
                        <task_id type="int">6356</task_id>
                        <detailed_report_url type="str">/reports/detailed/</detailed_report_url>
                        <name type="str">Planning</name>
                        <internal_cost type="float">0.0</internal_cost>
                        <budget type="null"/>
                        <budget_spent_percentage type="null"/>
                        <total_hours type="float">0.0</total_hours>
                        <over_budget type="null"/>
                        <billed_rate type="float">0.0</billed_rate>
                    </item>
                    <item type="dict">
                        <archived type="bool">False</archived>
                        <budget_spent type="float">0.0</budget_spent>
                        <billable_hours type="float">0.0</billable_hours>
                        <billable type="bool">True</billable>
                        <billable_amount type="float">0.0</billable_amount>
                        <budget_left type="null"/>
                        <over_budget_percentage type="null"/>
                        <task_id type="int">6357</task_id>
                        <detailed_report_url type="str">/detailed/123</detailed_report_url>
                        <name type="str">Planning</name>
                        <internal_cost type="float">0.0</internal_cost>
                        <budget type="null"/>
                        <budget_spent_percentage type="null"/>
                        <total_hours type="float">0.0</total_hours>
                        <over_budget type="null"/>
                        <billed_rate type="float">0.0</billed_rate>
                    </item>
                </tasks>

****更新****

根据DAXaholic的回答,我添加了这个:

     tree = ET.fromstring(xmldata)
     for item in tree.iterfind('tasks/item'):
      idtag = ET.Element('id')
      idtag.text = '555666'
      item.insert(0, idtag)

不确定如何完成此操作,因此我需要使用更新的数据。

1 个答案:

答案 0 :(得分:1)

这样的事情会给你一个想法

root = ET.fromstring(xmldata)
for item in root.iterfind('tasks/item'):
    idtag = ET.Element('id')
    idtag.text = '555666'
    item.insert(0, idtag)
xmldata = ET.tostring(root, encoding="unicode")