scala - 如何使用 Circe Optics 解析嵌套的 Json 数组

标签 scala lenses circe

我使用 Circe Optics 阅读了 Circe 文档给出的示例。文档中的示例非常简单,因为节点的路径很容易找到。

在我的例子中,json 看起来像

import io.circe._, io.circe.parser._

val json = """[["a",{"entity":["foo"]}],["b",{"entity":["bar"]}]]"""

这是一个有效的 json,我可以使用 parse(json) 进行解析

但是我要如何编写一个镜头才能提取所有“foo”、“bar”。

最佳答案

如果您想要花哨的 JsonPath 样式,您可以使用 each 来选择 JSON 数组的每个匹配成员,因此您的路径可能如下所示:

import io.circe.optics.JsonPath

val entities = JsonPath.root.each.each.entity.each.string

然后假设您有以下 Json 值:

import io.circe.jawn.parse

val Right(json) = parse("""[["a",{"entity":["foo"]}],["b",{"entity":["bar"]}]]""")

您可以像这样使用 Traversal 路径:

scala> entities.getAll(json)
res0: List[String] = List(foo, bar)

scala> entities.modify(_ * 2)(json).noSpaces
res1: String = [["a",{"entity":["foofoo"]}],["b",{"entity":["barbar"]}]]

scala> entities.set("___")(json).noSpaces
res2: String = [["a",{"entity":["___"]}],["b",{"entity":["___"]}]]

您也可以显式构建路径,但它会涉及更多代码。

关于scala - 如何使用 Circe Optics 解析嵌套的 Json 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55994920/

相关文章:

generics - "Missing parameter type"在采用函数参数的重载泛型方法中

exception - 我的持久性类应该返回 Option 还是依赖异常?

haskell - "Wither"的 Profunctor 表示是什么?

haskell - 为什么我们需要 Control.Lens.Reified?

scala - 为任意 JSON 创建 `Decoder`

java - 线程 "main"java.lang.NoClassDefFoundError : scala/Product$class ( Java) 中的异常

scala - 如何实现单子(monad)解析?

haskell - 使用镜头更新嵌套数据结构

json - Circe:高效解码多级ADT

json - ADT Json序列化/反序列化