1

ケース クラスの作成に使用される動的リスト内の文字をエスケープしたいと思います。

case class Profile(biography: String,
                  userid: String,
                  creationdate: String) extends Serializable

object Profile {

  val cs = this.getClass.getConstructors
  def createFromList(params: List[Any]) = params match {
    case List(biography: Any,
              userid: Any,
              creationdate: Any) => Profile(StringEscapeUtils.escapeJava(biography.asInstanceOf[String]),
                                            StringEscapeUtils.escapeJava(creationdate.asInstanceOf[String]),
                                            StringEscapeUtils.escapeJava(userid.asInstanceOf[String]))
  }
}

JSON.parseFull("""{"biography":"An avid learner","userid":"165774c2-a0e7-4a24-8f79-0f52bf3e2cda", "creationdate":"2015-07-13T07:48:47.924Z"}""")
  .map(_.get.asInstanceOf[scala.collection.immutable.Map[String, Any]])
  .map { 
    m => Profile.createFromList(m.values.to[collection.immutable.List])
   } saveToCassandra("testks", "profiles", SomeColumns("biography", "userid", "creationdate"))

次のエラーが表示されます。

scala.MatchError: List(An avid learner, 165774c2-a0e7-4a24-8f79-0f52bf3e2cda, 2015-07-13T07:48:47.925Z) (of class scala.collection.immutable.$colon$colon)

アイデアはありますか?

4

1 に答える 1

1

scala.util.parsing.json(Scala 2.11 以降非推奨になっている) よりも別の (外部の) JSON ライブラリを使用する方が簡単かもしれません。

json4sを使用した例の下に、優れた Scala Json ライブラリがたくさんあります。

import org.json4s._
import org.json4s.native.JsonMethods._

case class Profile(biography: String, userid: String, creationdate: String)

val json = """{
|  "biography":"An avid learner",
|  "userid":"165774c2-a0e7-4a24-8f79-0f52bf3e2cda", 
|  "creationdate":"2015-07-13T07:48:47.924Z"
|}""".stripMargin

parse(json).extract[Profile]
// Profile(An avid learner,165774c2-a0e7-4a24-8f79-0f52bf3e2cda,2015-07-13T07:48:47.924Z)
于 2015-09-03T09:45:43.970 に答える