Scala播放JSON类型转换

时间:2017-12-21 21:43:53

标签: scala type-conversion avro play-json

我目前正在努力进行Play的类型转换! Scala的Json库...
我的数据看起来像这样:

val myJson = Json.parse(...)

val mapping = Map[String, Option(JsValue)](
    "id" -> (myJson \ "Path" \ stringValue),
    "num" -> (myJson \ "Path" \ intValue),
    "precision" -> (myJson \ "Path" \ "floatValue")
)

另外,我有一个Avro Schema定义了每个字段的数据类型,在这种情况下它是:
- id:String
- num:Int
- 精度:浮动

如果我现在迭代字段并像这样检查Avro Schema的类型(请注意,在这种情况下,字段是要获取的值的名称,例如" id"):

    ...
    case Schema.Type.STRING => mapping.getOrElse(field, None) match {
      case Some(stringVal: JsValue) => stringVal.as[String]
      case None => null
    }
    case Schema.Type.INT => mapping.getOrElse(field, None) match {
      case Some(intVal) => intVal.as[Int]
      case None => null
    }
    case Schema.Type.FLOAT => mapping.getOrElse(field, None) match {
      case Some(floatVal) => floatVal.as[Float]
      case None => null
    }
    ...

我总是得到这个错误:

[org.apache.kafka.streams.processor.internals.StreamThread]  - Streams application error during processing in thread [StreamThread-1]:play.api.libs.json.JsResultException: JsResultException(errors:List((,List(JsonValidationError(List(error.expected.jsnumber),WrappedArray())))))

(注意:当然error.expected.jsnumber有时也可以是jsstring)

以下是我已经尝试过的转换方式,但是没有用(我有几个不同的映射,最后仍然包含None或给定类型的值):

floatVal.as[Float]
floatVal.as[JsNumber].as[Float]
floatVal.as[JsNumber].value.toFloat
Hi,

我目前正在努力进行Play的类型转换! Scala的Json库...
我的数据看起来像这样:

val myJson = Json.parse(...)

val mapping = Map[String, Option(JsValue)](
    "id" -> (myJson \ "Path" \ stringValue),
    "num" -> (myJson \ "Path" \ intValue),
    "precision" -> (myJson \ "Path" \ "floatValue")
)

另外,我有一个Avro Schema定义了每个字段的数据类型,在这种情况下它是:
- id:String
- num:Int
- 精度:浮动

如果我现在迭代字段并像这样检查Avro Schema的类型(请注意,在这种情况下,字段是要获取的值的名称,例如" id"):

    ...
    case Schema.Type.STRING => mapping.getOrElse(field, None) match {
      case Some(stringVal: JsValue) => stringVal.as[String]
      case None => null
    }
    case Schema.Type.INT => mapping.getOrElse(field, None) match {
      case Some(intVal) => intVal.as[Int]
      case None => null
    }
    case Schema.Type.FLOAT => mapping.getOrElse(field, None) match {
      case Some(floatVal) => floatVal.as[Float]
      case None => null
    }
    ...

我总是得到这个错误:

[org.apache.kafka.streams.processor.internals.StreamThread]  - Streams application error during processing in thread [StreamThread-1]:play.api.libs.json.JsResultException: JsResultException(errors:List((,List(JsonValidationError(List(error.expected.jsnumber),WrappedArray())))))

(注意:当然error.expected.jsnumber有时也可以是jsstring)

以下是我已经尝试过的转换方式,但是没有用(我有几个不同的映射,最后仍然包含None或给定类型的值):

floatVal.as[Float]
floatVal.as[JsNumber].as[Float]
floatVal.as[JsNumber].value.toFloat
floatVal.as[String].value.toFloat
floatVal.as[JsString].value.toString.toFloat
floatVal.as[String].toFloat
floatVal.as[String].value.toFloat
floatVal.as[JsString].value.toString.toFloat
floatVal.as[JsString].as[String].toFloat
floatVal.as[JsString].as[String].value.toFloat
floatVal.as[JsString].as[String].value.toString.toFloat

不知怎的,我对所有类型都有问题,只是在某些情况下,但我有它们...
同样有趣的是,即使类型为JsValue,当我使用调试器查看它们时,类型也会显示Js<type>,例如JsString代替JsValue 在某些情况下,但并非总是如此,它还会为Int类型显示JsString ...

为什么不将它们保留为JsValue

转换Play的正确方法是什么! Json类型?

谢谢 祝一切顺利 蒂姆

1 个答案:

答案 0 :(得分:0)

确保以对我有用的方式进行更新。

就我而言,我只是自己做了JsStringJsNumber,...转换,以便框架不会自己推断它的类型。