我目前正在努力进行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类型?
谢谢 祝一切顺利 蒂姆
答案 0 :(得分:0)
确保以对我有用的方式进行更新。
就我而言,我只是自己做了JsString
,JsNumber
,...转换,以便框架不会自己推断它的类型。