2013-10-11 118 views
1

我想解析JSON在斯卡拉,我不是很成功。 这里是我的JSON结构:斯卡拉解析递归JSON

{ 
    "data" : "test", 
    "field" : "test", 
    "listObj" : [{ 
     "data" : "testInner1", 
     "field" : "testInner1" 
    } , { 
     "data" : "testInner2", 
     "field" : "testInner2" 
    }], 
    "obj" : { 
     "data" : "testInner1", 
     "field" : "testInner1" 
    } 
} 

我使用的电梯进行解析。这里是我的代码:

import net.liftweb.json._ 

implicit val formats = DefaultFormats 
case class MyJson(data: String, field: String, obj: MyJson, listObj: List[MyJson]) 
val json = parse(""" 
{ 
    "data" : "test", 
    "field" : "test", 
    "listObj" : [{ 
     "data" : "testInner1", 
     "field" : "testInner1" 
    } , { 
     "data" : "testInner2", 
     "field" : "testInner2" 
    }], 
    "obj" : { 
     "data" : "testInner1", 
     "field" : "testInner1" 
    } 
}""") 
println(json.extract[Query]) 

我有上帝以下异常:

Caused by: net.liftweb.json.MappingException: No usable value for operation 
Did not find value which can be converted into java.lang.String 
at net.liftweb.json.Meta$.fail(Meta.scala:191) 
at net.liftweb.json.Extraction$.mkValue$1(Extraction.scala:357) 
at net.liftweb.json.Extraction$.net$liftweb$json$Extraction$$build$1(Extraction.scala:317) 
at net.liftweb.json.Extraction$$anonfun$13.apply(Extraction.scala:253) 
at net.liftweb.json.Extraction$$anonfun$13.apply(Extraction.scala:253) 
at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:244) 
at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:244) 
at scala.collection.immutable.List.foreach(List.scala:318) 
at scala.collection.TraversableLike$class.map(TraversableLike.scala:244) 
at scala.collection.AbstractTraversable.map(Traversable.scala:105) 
at net.liftweb.json.Extraction$.instantiate$1(Extraction.scala:253) 
at net.liftweb.json.Extraction$.newInstance$1(Extraction.scala:286) 
at net.liftweb.json.Extraction$.net$liftweb$json$Extraction$$build$1(Extraction.scala:315) 
at net.liftweb.json.Extraction$.mkValue$1(Extraction.scala:351) 
... 34 more 
Caused by: net.liftweb.json.MappingException: Did not find value which can be converted into java.lang.String 
at net.liftweb.json.Meta$.fail(Meta.scala:191) 
at net.liftweb.json.Extraction$.convert(Extraction.scala:403) 
at net.liftweb.json.Extraction$.net$liftweb$json$Extraction$$build$1(Extraction.scala:314) 
at net.liftweb.json.Extraction$.mkValue$1(Extraction.scala:351) 
... 46 more 

我一直在使用json4s尝试,但我可以想办法让它解析成case类。当我从我的JSON中删除obj和objList时,它运行良好。

任何人都可以指出我解析这种结构在Scala中读取它的方式吗?

+0

你的意思是“嵌套”,而不是“递归”?递归对象通常包含一个嵌套的指针。 – nafg

+0

nope。递归。 json对象包含它自己。 – Augusto

+0

它包含*本身*(如果是的话,你能帮我看看怎么样?),或者它包含一个* type *的对象? – nafg

回答

3

更改案例类定义,以便obj是一个可选值:

case class MyJson(data: String, 
    field: String, 
    // obj: MyJson,  // from 
    obj: Option[MyJson], // to 
    listObj: List[MyJson]) 

这是必要的,这样的JSON提取仍能产生和MyJson实例即使JSON缺少"obj"场(它在你的例子中的嵌套结构内)。

这对于listObj并不需要,因为json中缺少"listObj"字段仍然可以表示为空列表List[MyJson]

+0

非常感谢你!工作得很好:) – Augusto