scala - 使用 json4s 将 [String,Any] 映射到压缩 json 字符串

标签 scala json4s

我目前正在从不同的数据源中提取一些指标并将它们存储在类型为 Map[String,Any] 的 map 中。其中键对应于指标名称,值对应于指标值。我需要它或多或少是通用的,这意味着值类型可以是原始类型或原始类型列表。

我想将此映射序列化为 JSON 格式的字符串,为此我正在使用 json4s图书馆。问题是这似乎不可能,我看不到可能的解决方案。我希望像下面这样的东西开箱即用:)

val myMap: Map[String,Any] = ...    // extract metrics
val json = myMap.reduceLeft(_ ~ _)  // create JSON of metrics

导航 source code我见过json4s提供隐式转换以将原始类型转换为 JValue 's 和也转换 Traversable[A]/Map[String,A]/Option[A]JValue的(在可用的限制下,从 AJValue 的隐式转换,我理解它实际上意味着 A 是原始类型)。 ~运算符提供了一种很好的构建方式 JObject已用完 JField 's,它只是 (String, JValue) 的类型别名.

在这种情况下, map 值类型是 Any ,因此不会发生隐式转换,因此编译器会抛出以下错误:
                    value ~ is not a member of (String, Any)
[error]             val json = r.reduceLeft(_ ~ _)

我想要完成的事情有解决方案吗?

最佳答案

由于您实际上只是在寻找 myMap 的 JSON 字符串表示形式,您可以使用 Serialization直接对象。这是一个小例子(如果使用原生版本的 json4s 将导入更改为 org.json4s.native.Serialization ):

编辑 : 添加 formats隐含的

 import org.json4s.jackson.Serialization

 implicit val formats = org.json4s.DefaultFormats

 val m: Map[String, Any] = Map(
   "name "-> "joe",
   "children" -> List(
     Map("name" -> "Mary", "age" -> 5),
     Map("name" -> "Mazy", "age" -> 3)
   )
 )
 // prints {"name ":"joe","children":[{"name":"Mary","age":5},{"name":"Mazy","age":3}]}
 println(Serialization.write(m)) 

关于scala - 使用 json4s 将 [String,Any] 映射到压缩 json 字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27842906/

相关文章:

java - 使用NewHadoopRDD时如何给出文件名?

scala - Spark本地测试报OutOfMemoryError,如何解决?

scala - EsHadoopIllegalArgumentException:无法检测ES版本Spark-ElasticSearch示例

json - 如何创建具有不同类型值的 Json 对象?

json4s 无法使用 mixin 特征序列化案例类

PostgreSQL 数字类型和带有 Play 的 anorm 解析器!斯卡拉 2.3

json - 从 anyContent 获取内容为 Json

java - 在反序列化期间将 POJO 映射到具有不可变列表的案例类

scala - 将.jar文件导入Scala环境

scala - json4s:将类型转换为 JValue