以下是一个示例代码,演示了如何从XML文件中填充字典。
import xml.etree.ElementTree as ET
def parse_xml(xml_file):
# 创建一个空字典
data = {}
# 使用ElementTree解析XML文件
tree = ET.parse(xml_file)
root = tree.getroot()
# 遍历XML文件的每个子元素
for child in root:
# 将XML元素的标签作为字典的键
tag = child.tag
# 将XML元素的文本内容作为字典的值
text = child.text
# 如果该标签已经作为字典的键存在,则将其值转换为一个列表
if tag in data:
if isinstance(data[tag], list):
data[tag].append(text)
else:
data[tag] = [data[tag], text]
else:
data[tag] = text
return data
# 示例用法
xml_file = 'example.xml'
result = parse_xml(xml_file)
print(result)
在上述代码中,首先导入了xml.etree.ElementTree
库,然后定义了一个名为parse_xml
的函数,该函数接受一个XML文件作为参数。在函数内部,首先创建了一个空字典data
来存储解析后的数据。
然后,使用ET.parse
函数将XML文件解析为一个ElementTree对象。通过调用getroot
方法获取XML文件的根元素。
接下来,通过迭代根元素的每个子元素,将子元素的标签作为字典的键,并将子元素的文本内容作为字典的值。如果该标签已经作为字典的键存在,则将其值转换为一个列表,并将新的值添加到列表中。如果标签作为字典的键不存在,则直接将值存储为字典的值。
最后,函数返回填充好数据的字典。
示例代码中给出了一个名为example.xml
的XML文件,可以根据实际情况修改文件路径和内容。运行代码后,将输出填充好数据的字典。