我想在map中解压缩元组来访问其中的一些值。
在Python中,我会这样做:
>>> [topic for topic, partition in [('x', 1), ('y', 2)]]
['x', 'y']这里,元组('x', 1), ('y', 2)被解压缩为topic, partition,然后我访问topic。
在Scala中,我只设法做到了这样:
List(('x', 1), ('y', 2)).map(_._1)但我希望将显式解压缩成元组作为迭代步骤(即使它引入了一些开销),因为我认为它可以提高代码的可读性。
我想实现这样的目标
List(('x', 1), ('y', 2)).map((topic, partition) => topic)不幸的是,它没有起作用:
> <console>:9: error: wrong number of parameters; expected = 1
List(('x', 1), ('y', 2)).map((topic, partition) => topic)其他尝试(如List(('x', 1), ('y', 2)).map(Tuple2(topic, partition) => topic))也失败了。
有任何方法可以实现类似于我在Python中的功能吗?
发布于 2014-02-14 10:29:41
你在找这个吗?
List(('x', 1), ('y', 2)).map {
case (topic, partition) => topic
}编辑:正如@senia建议的那样,还有一种同样的方法:
for {
(topic, partition) <- List(('x', 1), ('y', 2))
} yield topichttps://stackoverflow.com/questions/21776796
复制相似问题