我目前正在从不同的数据源中提取一些指标,并将它们存储在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的类型(在可用隐式转换的限制下)从AJValue,据我了解,这实际上意味着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/

10-11 22:12