如何在Dataweave-Mulesoft中进行日期操作

How to perform date operations in Dataweave-Mulesoft

我有一个逻辑可以过滤掉 30 天前加入的学生。我在 xml 元素中有加入日期和最后日期。我必须使用数据编织从这两个字段中减去日期。

<School>
  <joindate>2015-10-18T00:00:00.000-08:00</joindate>
  <lastdate>2016-01-18</lastdate>
</School>

有多个date and time functions available with XPath/XSLT 2.0 and greater. It appears that DataWeave supports up to XSLT 3.0

以下表达式将解决所有 School 元素,其中 lastdatejoindate 小于 30.

//School[days-from-duration(xs:date(lastdate) - xs:date(xs:dateTime(joindate))) lt 30]

尝试使用 DataWeave 日期时间操作:

https://docs.mulesoft.com/mule-user-guide/v/3.7/dataweave-reference-documentation#adding-a-period-of-time

从您的 XML 获取值并将它们存储在 DataWeave 的变量中,将它们转换为 :date 并在脚本中减去它们。

这是一个为您提供对象的示例,我认为您可以从那里修复它?

%dw 1.0
%output application/java
%var join = payload.School.joindate as :date
%var last = payload.School.lastdate as :date
---
period: join - last