首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Scala:用通配符映射键?

Scala:用通配符映射键?
EN

Stack Overflow用户
提问于 2014-05-28 00:36:21
回答 4查看 1.6K关注 0票数 2

Scala可以用通配符来使用键吗?例如,表单(x,_)的元组?示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
scala> val t1 = ("x","y")
scala> val t2 = ("y","x")
scala> val m = Map(t1 -> "foo", t2 -> "foo")

scala> m(("x","y"))
res5: String = foo

scala> m(("x",_))
<console>:11: error: missing parameter type for expanded function ((x$1) => scala.Tuple2("x", x$1))
              m(("x",_))
                     ^

如果有一种方法可以检索所有(composite_key,value) pares,其中只定义了组合键的一部分,那就太好了。在Scala中获得相同功能的其他方法?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2014-05-28 05:31:08

使用这样的理解:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
for ( a @ ((k1,k2), v) <- m  if k1 == "x" ) yield a
票数 1
EN

Stack Overflow用户

发布于 2014-05-28 00:40:52

使用收集怎么样?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Map( 1 -> "1" -> "11", 2 -> "2" -> "22").collect { case (k@(1, _), v ) => k -> v }
票数 2
EN

Stack Overflow用户

发布于 2014-05-28 00:49:44

一般来说,你可以做这样的事情

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
m.filter(m => (m._1 == "x"))

但是在您的特定示例中,它仍然只返回一个结果,因为Map每个键只有一个条目。如果您的密钥本身是复合的,那么它确实更有意义:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
scala>  Map((1,2)->"a", (1,3)->"b", (3,4)->"c").filter(m => (m._1._1 == 1))
res0: scala.collection.immutable.Map[(Int, Int),String] = Map((1,2) -> a, (1,3) -> b)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23906580

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文