我使用的是Facebook图形API,响应与此类似:
{
"data": [
{
"id": "311620272349920_311718615673419",
"from": {
"id": "1456046457993048",
"name": "Richard Ettinson"
},
"to": {
"data": [
{
"id": "311620272349920",
"name": "Barbara Fallerman"
}
]
},
"with_tags": {
"data": [
{
"id": "311620272349920",
"name": "Barbara Fallerman"
}
]
},
"message": "I was gong out with her",
"actions": [
{
"name": "Comment",
"link": "https://www.facebook.com/311620272349920/posts/311718615673419"
},
{
"name": "Like",
"link": "https://www.facebook.com/311620272349920/posts/311718615673419"
}
]
}
我设法通过
提取from
字段
val extracted = (json \ "data" \"from").extract[PostFrom]
但是我担心如果我使用这种技术,我需要多次传递Json来提取我需要的所有值,这可能会导致性能不佳。
我究竟如何从非相似对象数组中将这些字段提取到案例类中?
我尝试使用以下case classes
:
abstract class BaseResponse()
case class Data(list:List[Post])
case class Post(id: String, post: PostFrom) extends BaseResponse
case class PostFrom(id: String, name:String)
哪个总是导致一个空列表,有没有办法找回一个Data
类,其中包含我感兴趣的某些类的列表? (例如顶级id
,from
和with_tags
)
答案 0 :(得分:5)
我发现的一种可能性是使用更多案例类而不是继承:
case class Root[T](data:Option[T])
case class Post(id: String, from: From, message: String)
case class From(id: String, name:String)
基本上必须有一个根对象,它接受某种图形响应对象,另外它是可选的,因此如果解析响应有问题,它就不会抛出异常。
然后我以下列方式使用它:
val body = r.entity.asString
val json = parse(r.entity.asString)
val root = json.extract[Root[Post]]
root.data match {
case Some(post) =>
val tagger = Tagger(post.from.id, post.from.name, post.id, post.message)
log.info(s"We received $tagger")
originalSender ! RetrievedTagger(tagger)
case None => originalSender ! NoTaggerFound
}