19

我有一张地图:

Map("key1" -> Some("value1"), "key2" -> None, "key3" -> Some("value3"))

我想删除所有None元素并展平地图。实现这一目标的最简单方法是什么?我只发现了这种方式:

Map("key1" -> Some("value1"), "key2" -> None, "key3" -> Some("value3")).filter(_._2.nonEmpty).map(item => (item._1 -> item._2.getOrElse(Nil)))

结果是:

Map(key1 -> value1, key3 -> value3)

你知道更好的方法吗?

4

5 回答 5

41

我对模式匹配的看法是:

Map("key1" -> Some("value1"), "key2" -> None, "key3" -> Some("value3")).collect {
  case (key, Some(value)) => key -> value
}
// Map(key1 -> value1, key3 -> value3)

收集诸如组合地图+过滤器之类的行为

于 2013-06-19T08:14:08.623 回答
20

您可以使用理解 + 模式匹配:

for((k, Some(v)) <- yourMap) yield k -> v
于 2015-09-15T17:12:11.097 回答
4

在地图上使用分区,像这样,

val (flattened,_) = map.partition(_._2.isDefined)
于 2015-09-16T06:08:45.127 回答
1

我的理解是:

val m = Map("key1" -> Some("value1"), "key2" -> None, "key3" -> Some("value3"))
for( (key,value) <- m if(value.isDefined)) yield (key,value.get)
于 2013-06-19T09:42:50.353 回答
0

您也可以定义以下帮助程序,这允许更紧凑的语法

implicit class RichPairedOptionIterableOps[A, B, Repr[_]](
    iterable: IterableOps[(A, Option[B]), Repr, Repr[(A, Option[B])]]
  ) {
    def collectWithSome: Repr[(A, B)] = iterable.collect { case (a, Some(b)) => a -> b }
    def collectWithNone: Repr[A] = iterable.collect { case (a, None) => a }
}

在你的例子中:

Map("key1" -> Some("value1"), "key2" -> None, "key3" -> Some("value3")).collectWithSome
于 2021-04-14T14:14:53.493 回答