我被困在试图通过返回结果来平平一个Seq[Seq[]]。所以我拥有的是:
def getListsByLC(lcId: Int): Action[AnyContent] = Action.async {
listRepo.getListsByLC(lcId).flatMap { lists =>
val items: Seq[Future[Seq[Item]]] = lists.map { list =>
itemRepo.getItemsByList(list.id)
}
Future.sequence(items).map { result =>
Ok(Json.obj("lists" -> lists, "items" -> result))
}
}
}结果显然是array of arrays

现在,我想要做的是flatten这个Future.sequence,以便只有一个数组包含所有项。与我发现的类似版本一样,我也尝试过这样做:
def getListsByLC(lcId: Int): Action[AnyContent] = Action.async {
listRepo.getListsByLC(lcId).flatMap { lists =>
val items: Seq[Future[Seq[Item]]] = lists.map { list =>
itemRepo.getItemsByList(list.id)
}
Future.sequence(items).map(._flatten) { result =>
Ok(Json.obj("lists" -> lists, "items" -> result))
}
}
}这里我得到了这个编译错误:

很抱歉截图的质量很差。有什么想法吗?提前感谢!
发布于 2017-09-02 14:33:07
您需要调用_.flatten而不是._flatten,并且在平放序列之后缺少一个额外的.map调用:
Future.sequence(items).map(_.flatten).map { result =>
Ok(Json.obj("lists" -> lists, "items" -> result))
}https://stackoverflow.com/questions/46014686
复制相似问题