有没有办法使用lift-json库的JObject类来像Map一样操作?
例如:
我注意到有一个 values 函数,它打印出一个 Map,但实际对象是 JValue.this.Values?
示例代码如下:
scala> record.values res43: record.Values = Map((_id,Map($oid -> 4ca63596ae65a71dd376938e)), (foo,bar), (size,5))
scala> record.values("foo") :12: error: record.values of type record.Values does not take parameters record.values("foo")
在 lift-json 库中,有提取 case class 的案例,但在这种情况下,我不知道 JSON 模式。
例如:
val json = """
{ "_id" : { "$oid" : "4ca63596ae65a71dd376938e"} , "foo" : "bar" , "size" : 5}
"""
val record = JsonParser.parse(json)
record: net.liftweb.json.JsonAST.JValue = JObject(List(JField(_id,JObject(List(JField($oid,JString(4ca63596ae65a71dd376938e))))), JField(foo,JString(bar)), JField(size,JInt(5))))
</code>
我希望 record("foo") 返回 "bar"。我注意到有一个 values 函数,它打印出一个 Map,但实际对象是 JValue.this.Values?
示例代码如下:
scala> record.values res43: record.Values = Map((_id,Map($oid -> 4ca63596ae65a71dd376938e)), (foo,bar), (size,5))
scala> record.values("foo") :12: error: record.values of type record.Values does not take parameters record.values("foo")
在 lift-json 库中,有提取 case class 的案例,但在这种情况下,我不知道 JSON 模式。