繁体   English   中英

Scala:如何将Seq [Array [String]]转换为Seq [Double]?

[英]Scala: How to convert a Seq[Array[String]] into Seq[Double]?

我需要将Seq [Array [String]]类型的数据拆分为两个Seq [Double]类型的项。

样本数据:([4.0 | 1492168815],[11.0 | 1491916394],[2.0 | 1491812028])。

我使用了var action1, timestamp1 = seq.map(t => (t.split("|"))).flatten.asInstanceOf[Seq[Double]]但没有得到预期的结果。 寻找有价值的建议。

假设您输入的格式为"[double1|double2]"

scala> Seq("[4.0|1492168815]","[11.0|1491916394]","[2.0|1491812028]")
res72: Seq[String] = List([4.0|1492168815], [11.0|1491916394], [2.0|1491812028])

删除[] ,然后除以\\\\| | 是正则表达式中的元字符。

scala> res72.flatMap {_.dropRight(1).drop(1).split("\\|").toList}.map{_.toDouble}
res74: Seq[Double] = List(4.0, 1.492168815E9, 11.0, 1.491916394E9, 2.0, 1.491812028E9)

或者你可以做

scala> val actTime = seq.flatMap(t => t.map(x => { val temp = x.split("\\|"); (temp(0), temp(1))}))
actTime: Seq[(String, String)] = List((4.0,1492168815), (11.0,1491916394), (2.0,1491812028))

并将它们分为两个Seq[Double]

scala> val action1 = actTime.map(_._1.toDouble)
action1: Seq[Double] = List(4.0, 11.0, 2.0)

scala> val timestamp1 = actTime.map(_._2.toDouble)
timestamp1: Seq[Double] = List(1.492168815E9, 1.491916394E9, 1.491812028E9)

如果输入中可能包含非双精度数据,则应使用Try进行更安全的Double转换,

scala> Seq("[4.0|1492168815]","[11.0|1491916394]","[2.0|1491812028]", "[abc|abc]")
res75: Seq[String] = List([4.0|1492168815], [11.0|1491916394], [2.0|1491812028], [abc|abc])

scala> import scala.util.Success
import scala.util.Success

scala> import scala.util.Try
import scala.util.Try

scala> res75.flatMap {_.dropRight(1).drop(1).split("\\|").toList}
            .map{d => Try(d.toDouble)}
            .collect {case Success(x) => x }
res83: Seq[Double] = List(4.0, 1.492168815E9, 11.0, 1.491916394E9, 2.0, 1.491812028E9) 

提取输入列表中每个项目的正则表达式组,并用[| ]

val pat = "\\[(.*)\\|(.*)\\]".r

因此,如果我们假设输入

val xs = List("[4.0|1492168815]","[11.0|1491916394]","[2.0|1491812028]")

考虑

xs.map { v => val pat(a,b) = v; (a.toDouble, b.toLong) }.unzip

我们将pat定义的正则表达式应用于列表的每个项目,对每个项目的每个组进行元组化,最后将它们unzip ,以便将元组一分为二。

(List(4.0, 11.0, 2.0),List(1492168815, 1491916394, 1491812028))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM