如何解决嵌套属性匹配条件的过滤器列表
我有以下案例类:
case class Reduction(value: Int,label: String)
case class Variant(id: String,name: String,reductions: List[Reduction])
case class Item(id: String,variants: List[Variant])
我从解析的 JSON 中得到一个 List[Item]
。现在我想过滤掉每个变体,这些变体的减少与特定的减少标签不匹配。
用下面的例子想象一下:
List(
Item("1234","Train ticket from A-B",List(
Variant("1","short way",List(Reduction(50,"Half fare"),Reduction(0,"Adult"))),Variant("2","long way",List(Reduction(0,"Adult")))
)
),Item("5678","Train ticket from B-C","Half fare"))),"Adult")))
)
)
)
我最终需要以 List[Item]
的形式:
所有项目,它们都有一个变体,可以保持给定的减少。例如。如果我需要过滤“半价”,我希望过滤后的 List[Item] 包含
仅包含变体 1 的项目 1234 和仅包含变体 1 的项目 5678。过滤只需在变体级别进行。
我知道我必须以某种方式使用 fold
或 reduce
,但我正在努力让代码运行。
我的尝试看起来有点像这样:
items.reduce(i => i.variants.reduce(v => checkLabel(v.reductions,requiredLabel) )
由于我是函数式编程的新手,因此我在此寻求有关如何正确解决此问题的建议。任何解释都会有所帮助。
解决方法
如果您想保留没有匹配变体的项目,您可以:
val requiredLabel = "Half Fare"
items.map(item =>
item.copy(variants = item.variants.filter(_.reduction.exists(_.label == requiredLabel)))
).filter(_.variants.nonEmpty)
代码在 Scastie 运行。
,你可能需要使用这样的东西:
考虑示例中的以下案例类:
case class Reduction(value: Int,label: String)
case class Variant(id: String,name: String,reduction: Reduction)
case class Item(id: String,variants: List[Variant])
您可以在 items: List[Item]
上进行如下操作:
items.filter(_.variants.exists(variant => checkLabel(variant.reduction,requiredLabel)))
很难理解你的意思,但是这个过滤了所有包含一些变体的项目,checkLabel
为它们返回 true
尝试根据您的特定用途更改它或编辑帖子并提供更清晰的详细信息,我会尽力提供帮助:)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。