我目前正在从不同的数据源中提取一些指标,并将它们存储在Map[String,Any]
类型的映射中,其中的键对应于指标名称,而值对应于指标值。我需要这个或多或少是通用的,这意味着值类型可以是原始类型或原始类型列表。
我想将此地图序列化为JSON格式的字符串,为此,我正在使用json4s
库。问题是,这似乎是不可能的,我看不出有可能的解决方案。我希望像下面这样的东西可以开箱即用:)
val myMap: Map[String,Any] = ... // extract metrics
val json = myMap.reduceLeft(_ ~ _) // create JSON of metrics
浏览source code时,我已经看到
json4s
提供了隐式转换,以便将原始类型转换为JValue
的类型,也将Traversable[A]/Map[String,A]/Option[A]
转换为JValue
的类型(在可用隐式转换的限制下)从A
到JValue
,据我了解,这实际上意味着A
是原始类型)。 ~
运算符提供了一种在JObject
之外构造JField
的好方法,这只是(String, JValue)
的类型别名。在这种情况下,映射值类型为
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 - Map [String,Any]使用json4s压缩json字符串,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34146612/