7

我遇到了这个关于使用 Jerkson 在 Scala 中处理 JSON 的优秀教程。特别是,我对将 JSON 反序列化为用户定义的案例类感兴趣。文章有一个简单的例子

case class Simple(val foo: String, val bar: List[String], val baz: Map[String,Int])

object SimpleExample {
  def main(args: Array[String]) {
    import com.codahale.jerkson.Json._
    val simpleJson = """{"foo":42, "bar":["a","b","c"], "baz":{"x":1,"y":2}}"""
    val simpleObject = parse[Simple](simpleJson)
    println(simpleObject)
  }
}

我运行它时遇到此错误,我在 Play 2.0.1、Scala 2.9.1-1、Jerkson 0.5.0 上。

Execution exception [[ParsingException: Unable to find a case accessor

在 Google Groups 上也找到了这个,但它没有帮助。

有任何想法吗?

4

1 回答 1

6

不幸的是,我不认识 Jerkson,但 Spray-Json 让这类事情变得简单。下面的示例来自Spray-Json 自述文件

 case class Color(name: String, red: Int, green: Int, blue: Int)

object MyJsonProtocol extends DefaultJsonProtocol {
  implicit val colorFormat = jsonFormat4(Color)
}

import MyJsonProtocol._

val json = Color("CadetBlue", 95, 158, 160).toJson
val color = json.convertTo[Color]

这是与某人的 git 存储库略有不同的示例:

package cc.spray.json.example

import cc.spray.json._


object EnumSex extends Enumeration {
  type Sex = Value
  val MALE = Value("MALE")
  val FEMALE = Value("FEMALE")
}

case class Address(no: String, street: String, city: String)

case class Person(name: String, age: Int, sex: EnumSex.Sex, address: Address)

object SprayJsonExamples {
  def main(args: Array[String]) {
    val json = """{ "no": "A1", "street" : "Main Street", "city" : "Colombo" }"""
    val address = JsonParser(json).fromJson[Address]
    println(address)

    val json2 = """{ "name" : "John", "age" : 26, "sex" : 0 , "address" : { "no": "A1", "street" : "Main Street", "city" : "Colombo" }}"""

    val person = JsonParser(json2).fromJson[Person]
    println(person)
  }
}
于 2012-11-14T06:28:51.770 回答