0

0

Excel数据如何转换为复杂的XML结构?

星降

星降

发布时间:2026-01-29 06:49:24

|

574人浏览过

|

来源于php中文网

原创

Excel表结构映射嵌套XML需分层设计多sheet并用代码关联生成:Orders与OrderItems通过order_id关联,Python+pandas+xml.etree递归构建树形结构,避免扁平化或非法标签。

excel数据如何转换为复杂的xml结构?

Excel 中的表结构如何映射到嵌套 XML 元素

Excel 本身不支持直接导出为任意嵌套 XML,必须借助外部工具或代码做结构转换。关键在于把 Excel 的二维表逻辑(行/列)对应到 XML 的树形逻辑(父子/兄弟)。常见错误是把每行硬编码成一个 ,结果生成扁平 XML,无法表达“订单→多个商品→每个商品有属性”这类关系。

实操建议:

  • 先在 Excel 中用多张 sheet 分层:比如 Orders 表存主单信息,OrderItems 表存明细,并用 order_id 关联
  • 避免在单个单元格里塞 JSON 或逗号分隔值——XML 解析器不会自动拆解它们
  • 如果字段名含空格或中文,导出前重命名为 customer_nameitem_sku 等合规标识符,否则生成的 XML 标签名会非法

用 Python + pandas + xml.etree 处理关联表

这是最可控的方式,适合中等数据量(万行以内)。核心思路是:读取各 sheet → 构建内存中的对象关系 → 递归生成 XML 节点。

注意 pandas.read_excel() 默认只读第一个 sheet,多 sheet 需显式传参;xml.etree.ElementTree 不支持命名空间缩写(如 ns:tag),要手动设 root.set('xmlns:ns', '...')

import pandas as pd
import xml.etree.ElementTree as ET

orders = pd.read_excel('data.xlsx', sheet_name='Orders') items = pd.read_excel('data.xlsx', sheet_name='OrderItems')

root = ET.Element('orders', xmlns='https://www.php.cn/link/285dbe36b6cab6c192769b2d22d9150a')

for _, order_row in orders.iterrows(): order_elem = ET.SubElement(root, 'order') ET.SubElement(order_elem, 'id').text = str(order_row['order_id']) ET.SubElement(order_elem, 'date').text = str(order_row['order_date'])

# 关联该订单下的所有 item
order_items = items[items['order_id'] == order_row['order_id']]
items_elem = ET.SubElement(order_elem, 'items')
for _, item_row in order_items.iterrows():
    item_elem = ET.SubElement(items_elem, 'item')
    ET.SubElement(item_elem, 'sku').text = str(item_row['sku'])
    ET.SubElement(item_elem, 'qty').text = str(item_row['quantity'])

tree = ET.ElementTree(root) tree.write('output.xml', encoding='utf-8', xml_declaration=True)

Power Query(Excel 内置)能否生成嵌套 XML?

不能直接生成,但可作为预处理工具:把原始表转成符合 XML 结构的「宽表」或「JSON 字符串列」,再导出后用其他工具转换。例如,用 Power Query 的 Table.Group() 把明细行聚合成列表,再用 Json.FromValue() 转成 JSON 字符串——虽然不是 XML,但比原始 Excel 更接近嵌套结构,后续用 Python 的 json.loads() + dict2xml 类库能省去手动 join 逻辑。

Android 本地数据存储 中文WORD版
Android 本地数据存储 中文WORD版

本文档主要讲述的是Android 本地数据存储;对于需要跨应用程序执行期间或生命期而维护重要信息的应用程序来说,能够在移动设备上本地存储数据是一种非常关键的功能。作为一名开发人员,您经常需要存储诸如用户首选项或应用程序配置之类的信息。您还必须根据一些特征(比如访问可见性)决定是否需要涉及内部或外部存储器,或者是否需要处理更复杂的、结构化的数据类型。跟随本文学习 Android 数据存储 API,具体来讲就是首选项、SQLite 和内部及外部内存 API。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以

下载

容易踩的坑:

  • Power Query 导出 JSON 时默认不保留数字类型,123 变成 "123",影响下游 XML 数值字段类型判断
  • Web.Page() 或自定义函数调用外部 API 生成 XML 属于高风险操作,Excel 会阻止或静默失败,不推荐

为什么 XSLT 不适合从 Excel 原始文件直接转换

XSLT 作用对象是 XML,不是 Excel 文件。有人试图用 xlsx 当作 ZIP 解压后读 xl/worksheets/sheet1.xml,再写 XSLT 处理——这条路理论上可行,但实际极难维护:Excel 的内部 XML 是为渲染服务的,含大量格式、合并单元格、样式引用节点(如 ),和业务数据完全脱钩。你得先写逻辑还原出“真实表格”,再映射到目标 XML,复杂度远超直接用 Python 处理 .xlsx

真正需要 XSLT 的场景,是已有标准 XML(如 UBL 发票),只需做字段映射和格式调整——这时它才高效可靠。

嵌套层级越深、关联规则越动态(比如“每个客户下最多取最近 3 笔订单”),就越依赖编程逻辑控制,而不是声明式模板。别被“XML 工具”这个词带偏方向。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

419

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

58

2025.12.04

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1900

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2091

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1064

2024.11.28

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 14.1万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号