我想提取 JSON 值使用理解
我的代码是这样的:
import net.liftweb.json._
val json = parse("""     
{
    "took": 212,
    "timed_out": false,
    "_shards": {
        "total": 5,
        "successful": 5,
        "failed": 0
    },
    "hits": {
        "total": 4,
        "max_score": 0.625,
        "hits": [
            {
                "_index": "siteindex",
                "_type": "posts",
                "_id": "1",
                "_score": 0.625,
                "_source": {
                    "title": "title 1",
                    "content": "content 1"
                },
                "highlight": {
                    "title": [
                        "<b>title</b> 1"
                    ]
                }
            },
            {
                "_index": "siteindex",
                "_type": "posts",
                "_id": "4",
                "_score": 0.19178301,
                "_source": {
                    "title": "title 4",
                    "content": "content 4"
                },
                "highlight": {
                    "title": [
                        "<b>title</b> 4"
                    ]
                }
            },
            {
                "_index": "siteindex",
                "_type": "posts",
                "_id": "2",
                "_score": 0.19178301,
                "_source": {
                    "title": "title 2",
                    "content": "content 2"
                },
                "highlight": {
                    "title": [
                        "<b>title</b> 2"
                    ]
                }
            },
            {
                "_index": "siteindex",
                "_type": "posts",
                "_id": "3",
                "_score": 0.19178301,
                "_source": {
                    "title": "title 3",
                    "content": "content 3"
                },
                "highlight": {
                    "title": [
                        "<b>title</b> 3"
                    ]
                }
            }
        ]
    }
}      
""")
我的“案例类”是这样的:
case class Document(title:String, content:String)
我的“为”是这样的:
val ret: List[Document] = for {
  JObject(child)                          <- json
  JField("title",       JString(title))   <- child
  JField("content",     JString(content)) <- child
} yield (Document( title, content  ))
我的“清单”是这样的:
ret: List[Document] = List(Document(title 1,content 1), Document(title 4,content 4), Document(title 2,content 2), Document(title 3,content 3))
直到这里一切都很好!
但现在我需要这样的东西:
List(Document2(1,<b>title</b> 1,content 1), Document2(4,<b>title</b> 4,content 4), Document2(2,<b>title</b> 2,content 2), Document2(3,<b>title</b> 3,content 3))
我需要以下值:
 "highlight": {
                    "title": [
                        "<b>*</b> *"
                    ]
                }
和这个:
"_id": "*",
在我的清单中。
我的“案例类”是这样的:
case class Document2(_id:String, title:String, content:String)
我试试这个,但它不起作用
val ret: List[Document2] = for {
  JObject(child)                          <- json
  JField("_id",         JString(_id))     <- child
  JField("title",       JString(title))   <- child
  JField("content",     JString(content)) <- child
} yield (Document2( _id, title, content  ))
我不知道,这个json是否有更好的数据提取方法
但结果是这样的:
<console>:23: warning: `withFilter' method does not yet exist on net.liftweb.json.JValue, using `filter' method instead
         JObject(child)                          <- json
ret: List[Document2] = List()
任何建议请
感谢您的帮助