我是Scala的新手,我必须使用一个接受Seq[Seq[Double]]类型参数的函数。但是,我的数据的类型是Array[(Double,Double)]。
我尝试使用.toSeq转换数据,但不起作用。
在这方面的任何修复都将受到高度赞赏。谢谢!
发布于 2018-12-19 05:27:35
val input: Array[(Double, Double)] = ...
val output: Seq[Seq[Double]] = input.map { case (x, y) => Seq(x, y) }不幸的是,没有一种通用的方法可以将元组类型安全地转换为标准库中的列表。但是,shapeless确实提供了以下功能:
import shapeless.syntax.std.tuple._
val input: Array[(Double, Double)] = ...
val output: Seq[Seq[Double]] = input.map(_.toList)Shapeless足够智能,可以在元组包含不同类型的组件的情况下计算出最低上限:
val input: Array[(Double, Int)] = ...
// AnyVal is the closest type which both Double and Int are subtypes of
val output: Seq[Seq[AnyVal]] = input.map(_.toList)最后,还有一种仅使用标准库工具实现此目的的非类型安全方法。您可以相信,Scala中的所有元组都实现了Product特征,因此可以作为Any的集合进行迭代
val input: Array[(Double, Double)] = ...
val output: Seq[Seq[Double]] = input.map(_.productIterator.toSeq.asInstanceOf[Seq[Double]])这是安全的,只要你小心,但它确实需要一个显式的强制转换,而且它更详细。
如果您有大小相对较小的固定长度的元组,那么我认为使用基于部分函数的方法更好。否则,这取决于你,但我会使用shapeless,因为它是类型安全的,而且我在我的许多项目中也使用shapeless来做其他事情,所以它对我来说是免费的:)
https://stackoverflow.com/questions/53841179
复制相似问题