0

0

MuleSoft DataWeave如何处理复杂的XML映射?

煙雲

煙雲

发布时间:2026-01-24 09:40:56

|

857人浏览过

|

来源于php中文网

原创

DataWeave处理XML映射的关键是显式声明命名空间、用[*]处理重复节点、用mapObject+filterObject处理动态字段;必须区分@属性、$.text()文本和子元素,解析前先用write验证结构。

mulesoft dataweave如何处理复杂的xml映射?

DataWeave 处理复杂 XML 映射的关键不在“能不能”,而在于你是否提前拆解了 XML 的嵌套结构、命名空间和重复节点行为——多数失败都卡在 namespace 声明缺失或 mapObject 误用上。

XML 命名空间必须显式声明,否则字段全为空

DataWeave 默认不自动识别 XML 中的 xmlns,即使输入 XML 有 xmlns="http://example.com/ns",不声明就查不到任何子元素。

  • 在脚本顶部用 %namespace ns "http://example.com/ns" 绑定前缀(前缀名任意,但需与后续路径一致)
  • 访问元素时必须带前缀:payload.ns#Order.ns#Item,不能写 payload.Order.Item
  • 如果 XML 有多个命名空间(如 ns1ns2),每个都要单独声明,且不能省略前缀
  • 默认命名空间(无前缀)要用空字符串声明:%namespace "" "http://example.com/default"

重复节点(如多个 )必须用 [] 显式接收

XML 中的同名重复节点在 DataWeave 中不会自动转成数组;若你用 payload.ns#Order.ns#Item 访问,只取第一个——除非你明确告诉它“这是个列表”。

Mootion
Mootion

Mootion是一个革命性的3D动画创作平台,利用AI技术来简化和加速3D动画的制作过程。

下载
  • payload.ns#Order.ns#Item map ((item, index) -> {...}) 迭代处理每个 Item
  • 若源 XML 中 Item 可能单个或多个,统一用 payload.ns#Order.*ns#Item* 表示“零个或多个”,强制返回数组)
  • 避免直接写 payload.ns#Order.ns#Item[0] —— 当只有一个 Item 时会报错,因为非数组类型不支持下标

深层嵌套 + 条件过滤要用 mapObject + filterObject 组合,别硬写路径

当 XML 里有一堆动态 key(比如 john@ex.com),靠固定路径根本没法映射,得转成键值对再筛选。

  • 先用 payload.ns#Order.ns#Fields.*ns#Field mapObject { ($.@name): $.text() } 转成对象:{"email": "john@ex.com", "phone": "123"}
  • 再用 filterObject 留下需要的字段:... filterObject $ != null and $ != ""
  • 注意 .@name 是取属性,$.text() 是取文本内容(不是 $ 直接取值)
  • 如果字段名含特殊字符(如连字符),用括号包裹:{ ($.@'field-name'): $.text() }
%dw 2.0
output application/json
%namespace ns "http://example.com/order"
---
{
  orderId: payload.ns#Order.@id,
  items: payload.ns#Order.*ns#Item map ((item, index) -> {
    sku: item.ns#Product.@sku,
    qty: item.ns#Quantity as Number,
    price: item.ns#Price as Number
  }),
  metadata: payload.ns#Order.ns#Fields.*ns#Field 
    mapObject { ($.@name): $.text() } 
    filterObject $ != null and $ != ""
}

最常被忽略的是:XML 解析后,属性(@id)、文本($.text())、子元素(.ns#Child)三者类型不同,混用会静默失败或返回 null。动手前先用 write(payload, "application/xml") 看一眼解析结果,比猜快十倍。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

233

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

437

2024.03.01

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

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

1897

2024.04.01

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

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

2088

2024.08.01

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

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

1042

2024.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

278

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1492

2023.10.24

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

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

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