最推荐用xml.etree.ElementTree模块创建XML文件:先用ET.Element()建根节点,ET.SubElement()添加子节点并设.text和.set()属性,再用ET.ElementTree(root).write()保存,需指定encoding='utf-8'和xml_declaration=True;Python 3.9+可用ET.indent()自动缩进美化。
用Python创建XML文件最常用、最推荐的方法是使用内置的 xml.etree.ElementTree 模块。它轻量、标准、无需额外安装,适合大多数结构化数据导出场景。
这是最直观的方式:先构建元素树,再保存为文件。
ET.Element() 创建根节点ET.SubElement() 添加子节点,支持嵌套.text 设置文本内容,.set() 添加属性ET.ElementTree(root).write() 保存,注意设置 encoding='utf-8' 和 xml_declaration=True 保证格式规范示例:
import xml.etree.ElementTree as ET创建根元素
root = ET.Element("books")
添加子元素
book = ET.SubElement(root, "book", id="1") title = ET.SubElement(book, "title") title.text = "Python 编程入门" author = ET.SubElement(book, "author") author.text = "张三"
写入文件(带声明、UTF-8 编码、缩进需手动处理或用第三方库)
tree = ET.ElementTree(root) tree.write("books.xml", encoding="utf-8", xml_declaration=True)
默认 write() 不带缩进。Python 3.9 起可直接用 ET.indent() 自动美化结构。
tree.write() 前调用 ET.indent(tree, space=" ")
如果原始数据是字典,且结构不深,xmltodict 配合 json 思路更直观。
pip install xmltodict
示例:
import xmltodictdata = { "config": { "@version": "2.0", # @ 开头表示属性 "host": "localhost", "port": "8080", "debug": "true" } } xml_str = xmltodict.unparse(data, pretty=True) with open("config.xml", "w", encoding="utf-8") as f: f.write(xml_str)
encoding="utf-8" 并在 open() 或 write() 中统一编码
&、 会被自动转义(&、),这是正常行为,无需手动处理
ElementTree 支持但语法稍繁琐,建议查阅官方文档中 register_namespace() 用法不复杂但容易忽略