如何解决迭代 CompactBuffer-Spark 和 Scala
我是 Scala 的新手,熟悉 Python。我很难迭代 Iterator[String] 对象(Compact Buffer)。我试过 foreach 方法没有成功。
这是我的代码:
def CCF_Iterate(pair : (String,List[Iterable[String]]) ) = {
var key = pair._1
var values_iterate = pair._2
var min = pair._1
val list_values = List.empty[String]
for (value <- values_iterate) {
if (min > value ) {
min = value}
list_values:+ value
}
我收到此错误消息:
found : Iterable[String]
required : String
if (min > value )
^
有人可以帮我遍历这个列表吗?非常感谢
解决方法
values_iterate
是一个 Iterable
列表(另一个列表或其他东西),因此当您遍历它时,值是 Iterable
- 因此是错误。您需要先.flatten
。
此外,list_values:+ value
并没有真正做任何事情:List
是不可变的,它会返回一个带有附加值的新副本,但您将其丢弃。
此外,循环中的 if
语句也无关紧要:您正在寻找循环中的最小值,但从不使用它。
另一件事是附加到 List
是非常低效的(它是一个链表,所以附加到它是 O(n)),在代码中看到这样的东西通常是一个危险信号。
最后,在 Scala 中我们很少使用 var
,而且几乎从不使用循环。
通常,要创建一个平面的值列表,您只需执行
val list = pair._2.flatten
。
要找到列表中的最小值,您可以执行 list.min
。
如果你想用参数中给定的值绑定它,那么你做 math.min(min,list.min)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。