我需要总结以下小时和分钟。
[{"hours": 20.50},{"hours":30.55}]
预期结果应该是:[{"hours" : 51.45}]
如果在 java 中没有帮助,您认为我可以如何在 dataweave 2.0 中添加时间。
我不确定我们是否可以利用包含 DW 的时间类型来解决这个问题,所以我编写了一个使用自定义类型 HoursMinutes 的解决方案,它让小时数超过 24,将 Number 解析为 HoursMinutes,添加它们,最后再次将其转换为 Number。
也许我把它复杂化了……哈哈
%dw 2.0
output application/json
type HoursMinutes = {hour:Number, minute: Number}
fun toHours(n: Number): HoursMinutes = do {
var split = n as String splitBy "."
var fromMin = floor(split[1] as Number / 60)
---
{hour:floor(n) + fromMin, minute:split[1] as Number mod 60}
}
fun add(hour1:HoursMinutes, hour2: HoursMinutes): HoursMinutes = do {
var fromMin = floor((hour1.minute + hour2.minute) / 60)
---
{hour: hour1.hour + hour2.hour + fromMin, minute: (hour1.minute + hour2.minute) mod 60}
}
fun toNumber(h: HoursMinutes) = (h.hour as String ++"."++ h.minute as String) as Number
---
[
{
"hours": toNumber(payload reduce ((item, accumulator:HoursMinutes = {hour:0, minute:0}) -> accumulator add toHours(item.hours)))
}
]