如何将 java 转换为嵌套的 Scala 数据类型

How to convert between java to scala datatype nested

我有一个函数是 returning List<String[]> ,我可以将它修改为 return 其他东西,按比例我调用的函数期望输入为: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") )) ) 

您需要将数组转换为 Tuple4s。如果你能保证你的数组总是大小为 4,并且假设它们的顺序与元组要求的顺序相同,那么你可以简单地这样做:

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

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

您需要 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 + ")"

}

假设每个 Array 的大小都是固定的 4(基于您的示例数据),对于列表中的每个 Array,您可以使用模式匹配来提取 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)
// )

请注意,Tuple4Product4 的规范表示,后者又扩展了 Product。对于 Java 和 Scala 集合之间的常见转换,这里有一个相关的 doc.