如何在Java到嵌套的Scala数据类型之间进行转换

时间:2018-08-28 23:12:58

标签: java scala scala-collections

我有一个返回List<String[]>的函数,我可以对其进行修改以返回其他内容,按比例,我正在调用的函数期望输入为:Seq[Product]

我遇到以下错误:

[scalac-2.11]  found   : List[Array[String]]
[scalac-2.11]  required: Seq[Product]

我是scala的新手,我该怎么做?

我需要调用的api期望输入如下:

 Seq( ("id", "string", "id", "string"), ("my_date", "string", "my_date", "string") )) ) 

3 个答案:

答案 0 :(得分:2)

您需要transform List[Array[String]] => List[scala.Product]才能匹配您正在调用的api的输入类型。

说,您的api如下:

scala> def glueApi(data: Seq[Product]) = "do something"
glueApi: (data: Seq[Product])String

转换:List[Array[String]] => List[scala.Product]

scala> val data = List(Array("id", "001", "id2", "002"), Array("date1", "data1", "date2", "data2"))
data: List[Array[String]] = List(Array(id, 001, id2, 002), Array(date1, data1, date2, data2))

scala> val dataProducts:List[Product] = data.map { case Array(a, b, c, d) => (a, b, c, d) }
dataProducts: List[Product] = List((id,001,id2,002), (date1,data1,date2,data2))

调用api:

scala> glueApi(dataProducts)
res3: String = do something

注意: TupleNProductN的暗示。-https://www.scala-lang.org/api/2.12.6/scala/Tuple4.html

case class Tuple4[+T1, +T2, +T3, +T4](_1: T1, _2: T2, _3: T3, _4: T4)
  extends Product4[T1, T2, T3, T4]
{
  override def toString() = "(" + _1 + "," + _2 + "," + _3 + "," + _4 + ")"

}

答案 1 :(得分:1)

假设Array每个都是固定大小4(基于样本数据),对于列表中的每个Array,您可以使用模式匹配来提取{{1 }}元素放入Array

Tuple4

请注意,import scala.collection.JavaConverters._ import scala.collection.mutable.ArrayBuffer val arrList: java.util.List[Array[String]] = ArrayBuffer( Array("id", "string", "id", "string"), Array("my_date", "string", "my_date", "string") ).asJava // arrList: java.util.List[Array[String]] = [[Ljava.lang.String;@1f50fe84, [Ljava.lang.String;@3380313d] val productList: Seq[Product] = arrList.asScala. map{ case Array(s1, s2, s3, s4) => (s1, s2, s3, s4) } // productList: Seq[Product] = ArrayBuffer( // (id,string,id,string), (my_date,string,my_date,string) // ) Tuple4的规范表示形式,它反过来又扩展了Product4。对于Java和Scala集合之间的常见转换,以下是相关的doc

答案 2 :(得分:0)

您需要将数组转换为Tuple4。如果可以保证数组的大小始终为4,并假设它们的顺序与元组所需的顺序相同,则可以简单地执行以下操作:

myList.map(arr => (arr(0), arr(1), arr(2), arr(3)))

但是,如果不能保证数组的大小为4,或者数组元素相对于元组要求而言是乱序的,那么您将不得不做一些额外的工作来处理这些情况。