我拥有的json看起来像这样:
{
"cards": [
{
"card_id":"1234567890",
"card_status":"active",
"card_expiration":{
"formatted":"01/20"
},
"debit":{
"masked_debit_card_number":"1111 **** **** 1111",
}
},
{
"card_id":"1234567891",
"card_status":"active",
"card_expiration":null,
"debit":{
"masked_debit_card_number":"2222 **** **** 2222",
}
}
]
}
我正在尝试使用此函数检索所有card_expiration
个字段值:
def getExpirations(json: Json) =
root
.cards
.each
.filter(root.card_status.string.exist(_ == "active"))
.card_expiration
.selectDynamic("formatted")
.string
.getAll(json)
问题是,上面的表达式只返回1个结果-对于第一张卡,但是我真的需要得到类似List(Some("01/20"), None)
的东西!在这种情况下我该怎么办?
答案 0 :(得分:3)
问题在于,当您完成formatted
步骤时,您将不再匹配null
到期时间。您可以执行以下操作:
import io.circe.Json, io.circe.optics.JsonPath.root
def getExpirations(json: Json) =
root
.cards
.each
.filter(root.card_status.string.exist(_ == "active"))
.card_expiration
.as[Option[Map[String, String]]]
.getAll(json)
或者:
import io.circe.Json, io.circe.generic.auto._, io.circe.optics.JsonPath.root
case class Expiration(formatted: String)
def getExpirations(json: Json) =
root
.cards
.each
.filter(root.card_status.string.exist(_ == "active"))
.card_expiration
.as[Option[Expiration]]
.getAll(json)
然后:
scala> getExpirations(io.circe.jawn.parse(doc).right.get)
res0: List[Option[Expiration]] = List(Some(Expiration(01/20)), None)
在没有更多上下文的情况下,我认为这不是用于光学的好用例。您最好将其解码为case类,或者使用游标。如果您可以提供更多信息,则会更容易分辨。