如何使用不同类型的值创建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)
我得到的,每个字段的类型在编译时没有定义.但是,如果序列化器无论如何进行模式匹配,为什么它不起作用呢?
谢谢!
你在这里采取了错误的方法。为了保持一致性,我强烈鼓励您使用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将自动处理缺失/可选参数。
| 归档时间: |
|
| 查看次数: |
8318 次 |
| 最近记录: |