有没有办法使用lift-json库的JObject类来像一个Map一样?我可以使用Scala lift-json库将JSON解析为Map吗?
例如:
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>
我本来期望的记录(“富”)返回“巴”
我注意到一个值函数,它打印出地图,但实际的对象是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")
有与升降JSON库提取案例类的例子,但在这种情况下,我不知道提前JSON模式。
这是一个case类解析地图作为参数相关答案http://stackoverflow.com/questions/5051290/deserializing-case-classes-with-mapstring-any-properties-with-lift-json/6310493#6310493 – 2011-06-10 18:57:33