微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

迭代 CompactBuffer-Spark 和 Scala

如何解决迭代 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 举报,一经查实,本站将立刻删除。