我有以下代码:
val lines = Source.fromFile("/home/cloudera/file_01").getLines().drop(1).toVector
我得到一个文件行向量 - 文件:
lines: Vector[String] = Vector(blk1|20170912|||||, ||||||, |c1|c2|c3|||, |201710|201711|201712|||, v1|1|4|9|||, v2|1||7|||, blk2||||||, ||||||, c4|c5|c6||||, |201710|201711|201712|||, h|h|h|h|h|h|h, j|j|j|j|j|j|j, k|k|k|k|k|k|k, m|m|m|m|m|m|m, ||||||, ||||||, ||||||, 201801|1|5||||, 201802|9|100||||, 201803|9|||||)
我当时想要做的是将每个条目作为一个String数组,然后放入一个String of Array数组。
我明白了,这很好:
scala> val current_line_values_1 = lines(3).split("\\|", -1).map{x => val trimmed = x.trim; if (trimmed.isEmpty) "empty string" else trimmed}
current_line_values_1: Array[String] = Array(empty string, 201710, 201711, 201712, empty string, empty string, empty string)
scala> val current_line_values_2 = lines(3).split("\\|", -1).map{x => val trimmed = x.trim; if (trimmed.isEmpty) "empty string" else trimmed}
current_line_values_2: Array[String] = Array(empty string, 201710, 201711, 201712, empty string, empty string, empty string)
在SBT控制台中以简单的方式完成此操作。
所以,我查看了ListBuffer,因为我想创建这两个列表,这些列表是所有行的子集。
我根据mutable.ListBuffer使用Alvin Alexander的例子如下:
var fruits = new ListBuffer[String]()
//var fruits = new ListBuffer[Array[String]]() - this made no difference either
fruits += current_line_values_1.toString
fruits += current_line_values_2.toString
我不得不使用toString来编译它。
我得到了正确数量的元素,但打印出来像这样:
saveLinesList1 = fruits.toList
// How to print 2 dimensional?
for (j <- 0 to (saveLinesList1.length - 1)) {
println("hello " + saveLinesList1(j))
val x = saveLinesList1(j)
for (k <- 0 to (x.length - 1)) {
println("hello 2 " + x(k))
}
} // End of for loop.
给了我:
hello [Ljava.lang.String;@51dd09f
hello 2 [
hello 2 L
hello 2 j
hello 2 a
hello 2 v
hello 2 a
内容发生了什么变化? Array [String]数组也没有帮助。看二维数组也没有清除它。
我需要的只是一个String数组的行数组。
答案 0 :(得分:2)
当您将toString
应用于Array
时,它将返回对象而不是String
值。而是尝试使用mkString
连接Array中的每个值并返回单个String
值。
尝试使用以下代码,
//no need to define it as var its already mutable
val fruits = new ListBuffer[String]()
fruits += current_line_values_1.mkString
fruits += current_line_values_2.mkString
//to print the ListBuffer
fruits.foreach(println(_))
如果您需要Array[String]
而不是String
,则可以使用以下内容
val fruits = new ListBuffer[Array[String]]()
fruits += current_line_values_1
fruits += current_line_values_2