/ / Jak przeanalizować json za pomocą spray json, który wykorzystuje skrzynkę wężową (podkreślenie) zamiast wielbłąda - json, scala, spray, spray-json

Jak parsować json za pomocą spray json, który wykorzystuje skrzynkę wężową (notatka podkreślenia) zamiast wielbłąda - json, scala, spray, spray-json

Jak sparsować json za pomocą spray json, który używa przypadku węża (notacja podkreślenia) zamiast wielbłąda?

Na przykład.

case class Test(subjectDescription: String)
"{"subject_description":"Medicine"}".parseJson.convertTo[Test]

powinien działać, a nie rzucać wyjątku.

Odpowiedzi:

6 dla odpowiedzi № 1

Lubię to:

case class Test(subjectDescription: String)
implicit val testFormat = jsonFormat(Test.apply, "subject_description")
"{"subject_description":"Medicine"}".parseJson.convertTo[Test]

Tutaj jest sztuczka jsonFormat funkcja pobiera argumenty łańcuchowe dla kluczy obiektów JSON.


1 dla odpowiedzi nr 2

Ta odpowiedź pochodzi z https://groups.google.com/forum/#!msg/spray-user/KsPIqWDK0AY/HcanflgRzMcJ. Umieszczenie go na SO, ponieważ SEO jest lepsze.

/**
* A custom version of the Spray DefaultJsonProtocol with a modified field naming strategy
*/
trait SnakifiedSprayJsonSupport extends DefaultJsonProtocol {
import reflect._

/**
* This is the most important piece of code in this object!
* It overrides the default naming scheme used by spray-json and replaces it with a scheme that turns camelcased
* names into snakified names (i.e. using underscores as word separators).
*/
override protected def extractFieldNames(classTag: ClassTag[_]) = {
import java.util.Locale

def snakify(name: String) = PASS2.replaceAllIn(PASS1.replaceAllIn(name, REPLACEMENT), REPLACEMENT).toLowerCase(Locale.US)

super.extractFieldNames(classTag).map { snakify(_) }
}

private val PASS1 = """([A-Z]+)([A-Z][a-z])""".r
private val PASS2 = """([a-zd])([A-Z])""".r
private val REPLACEMENT = "$1_$2"
}

object SnakifiedSprayJsonSupport extends SnakifiedSprayJsonSupport

import SnakifiedSprayJsonSupport._

object MyJsonProtocol extends SnakifiedSprayJsonSupport {
implicit val testFormat = jsonFormat1(Test.apply)
}