在 json4s 自述文件https://github.com/json4s/json4s#serializing-non-supported-types上给出的示例中,匹配仅在字段顺序为 {"start":0,"end":0} 时才有效。如果交换了开始和结束字段,则匹配不起作用。无论如何要编写以下大小写匹配,以使 JSON 字段排序无关紧要?
case JObject(JField("start", JInt(s)) :: JField("end", JInt(e)) :: Nil)
在 json4s 自述文件https://github.com/json4s/json4s#serializing-non-supported-types上给出的示例中,匹配仅在字段顺序为 {"start":0,"end":0} 时才有效。如果交换了开始和结束字段,则匹配不起作用。无论如何要编写以下大小写匹配,以使 JSON 字段排序无关紧要?
case JObject(JField("start", JInt(s)) :: JField("end", JInt(e)) :: Nil)
我没有使用过这个库,所以我不确定这是否是正确的方法:(我花了几分钟查看文档后想出了这个)
class IntervalSerializer extends CustomSerializer[Interval](format => (
{
case x: JObject =>
x.obj.sortBy { case (k,_) => k } match {
case JField("end", JInt(e)) :: JField("start", JInt(s)) :: Nil =>
new Interval(start = s.longValue(), end = e.longValue())
}
},
{
case x: Interval =>
JObject(JField("start", JInt(BigInt(x.startTime))) ::
JField("end", JInt(BigInt(x.endTime))) :: Nil)
}
))
这个想法是按字母顺序对字段进行排序,然后创建 Interval 类。
我有一个不同但相关的问题,让我发现了 json4s 中的“提取”功能。它解决了订购问题。
case x: JObject =>
Interval((x \ "start").extract[Int],(x \ "end").extract[Int])
如果你需要一个更复杂的例子,你可以查看这个github ticket。