Как конвертировать Java в тип данных Scala, вложенный - PullRequest
0 голосов
/ 29 августа 2018

У меня есть функция, которая возвращает 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 голосов
/ 29 августа 2018

вам нужно преобразовать 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

Примечание: TupleN подразумевается ProductN. - 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 + ")"

}
0 голосов
/ 29 августа 2018

Предполагая, что каждый Array имеет фиксированный размер 4 (на основе данных выборки), для каждого из Array в списке вы можете использовать сопоставление с шаблоном для извлечения элементов Array в Tuple4 * * 1005

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, которое, в свою очередь, расширяет Product. Для общих преобразований между коллекциями Java и Scala приведен соответствующий doc .

0 голосов
/ 29 августа 2018

Вам необходимо преобразовать массивы в Tuple4 с. Если вы можете гарантировать, что ваши массивы всегда имеют размер 4 и предполагать, что они находятся в том же порядке, что и кортежи, то вы можете просто сделать это:

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

Однако, если вы не можете гарантировать, что ваши массивы имеют размер 4 или если элементы массива не соответствуют порядку относительно требований к кортежу, вам придется проделать дополнительную работу для решения этих случаев.

...