如何使用不同类型的值创建Json对象?

exp*_*ert 5 json scala json4s

如何使用不同类型的值创建Json对象?

我正在使用spray-json

这是代码

val images : List[JsObject] = fetchImageUrls(url).map((url: String) => {
  JsObject(List(
        "link_path" -> JsString(url),
        "display_name" -> JsString("image"),
        "size" -> JsString(""),
        "modified" -> JsString(""),
        "thumbnail" -> JsString(url),
        "filename" -> JsString("image"),
        "is_dir" -> JsBoolean(x = false),
        "thumb_exists" -> JsBoolean(x = true)) )
  })

val jsonAst: JsObject = JsObject(List(
  "client" -> JsString("urlimages"),
  "view" -> JsString("thumbnails"),
  "contents" -> JsArray(images)
))
Run Code Online (Sandbox Code Playgroud)

它有效,但看起来很重.有没有办法用这样的代码定义json?

val images : List[List[(String, Any)]] = fetchImageUrls(url).map((url: String) => {
  List(
    "link_path" -> url,
    "display_name" -> "image",
    "size" -> "",
    "modified" -> "",
    "thumbnail" -> url,
    "filename" -> "image",
    "is_dir" -> false,
    "thumb_exists" -> true)
})

val jsonAst = List(
  "client" -> "urlimages",
  "view" -> "thumbnails",
  "contents" -> images
).toJson
Run Code Online (Sandbox Code Playgroud)

说这不起作用

Cannot find JsonWriter or JsonFormat type class for List[(String, Object)]
    ).toJson
      ^
Run Code Online (Sandbox Code Playgroud)

我得到的,每个字段的类型在编译时没有定义.但是,如果序列化器无论如何进行模式匹配,为什么它不起作用呢?

谢谢!

fla*_*ian 1

你在这里采取了错误的方法。为了保持一致性,我强烈鼓励您使用case class.

说你有这个

case class Image(
    url: String,
    size: Double,
    properties: Map[String][String]
    optionalProperty: Option[String]
    // etc.
);
Run Code Online (Sandbox Code Playgroud)

然后你使用parseanddecompose来处理这个问题。

val image = parse(jsonString).extract[Image]; // extracts an Image from JSON.
val jsonForImage: JValue = decompose(image);  // serializes an Image to JSON.
Run Code Online (Sandbox Code Playgroud)

如果你想将 a 序列List[Image]化为 JSON:

def serialize(images: List[Image]) : JValue = {
    for (image <- images) 
       yield decompose(image);
};
Run Code Online (Sandbox Code Playgroud)

要从 JSON 解析图像列表:

val images: List[Image] = parse(jsonString).extract[List[Image]];
Run Code Online (Sandbox Code Playgroud)

Option[SomeType]在 中使用Image case class将自动处理缺失/可选参数。