15

我试图在地图中找到一个键,给定一个值。我无法找出正确的谓词来使用“查找”功能:

val colors = Map(1 -> "red", 2 -> "blue")
def keyForValue(map: Map[Int, String], value: String) = {
    val bool = map.find{map.foreach{map.values(i) == value}}
        bool.key
  }

当我知道值时,如何遍历地图并找到键?

4

4 回答 4

19

您使用与 a 相同类型的谓词List,但请记住,您是在对 pairs进行评估(key,value),而不仅仅是值(并且还获得了 pair!)

简单的例子:

val default = (-1,"")
val value = "red"
colors.find(_._2==value).getOrElse(default)._1
于 2013-10-24T17:44:04.407 回答
2

findin的签名Mapfind(p: ((A, B)) ⇒ Boolean): Option[(A, B)]。所以谓词需要 aTuple2并且必须返回 a Boolean。请注意,我更改value为 anInt因为 key incolors也是Int.

scala> def keyForValue(map: Map[Int, String], value: Int) = {
     | colors.find({case (a,b) => a  == value})
     | }
keyForValue: (map: Map[Int,String], value: Int)Option[(Int, String)]

测试:

scala> keyForValue(colors, 1)
res0: Option[(Int, String)] = Some((1,red))

您还可以使用get

scala> colors.get(1)
res1: Option[String] = Some(red)
于 2013-10-24T17:41:57.080 回答
1

您始终可以使用抽象解决方案并将键与其值交换,将其存储在新映射中,然后搜索新映射:

val colors = Map(1 -> "red", 2 -> "blue")
def keyForValue(map: Map[Int, String], value: String) = {
  val revMap = map map {_.swap}
  val key = revMap(value)
  key
}

第三行将键与它们的值交换,并将其存储在revMap. (map map表示映射的名称,在这种情况下,是参数 map,然后是单词 map,然后{_.swap}实际将键与其值交换。

于 2015-11-13T23:04:41.937 回答
0

我会避免将地图传递给 find 方法,而是只将地图的传递给 find 方法。

这避免了处理Option[Int,String] - 相反它是Option[Int]

// sample data
val colors = Map(1 -> "red", 2 -> "blue", 3 -> "yellow")

// function you need
def keyForValue(theMap: Map[Int, String], theValue: String): Int = {

    val someKey = theMap.keys.find( k => theMap(k) == theValue )
    someKey match {
        case Some(key) => {
            println(s"the map contains ${key} -> ${theValue}")
            return key
        }
        case None => {
            println(s"a key was not found for ${theValue}")
            return -1
        }
    }
}

这给出了:

scala> val result = keyForValue( colors, "blue" )
the map contains 2 -> blue
result: Int = 2

scala>
于 2019-01-03T17:46:12.797 回答