从标准输入逐行阅读的Scala配方是什么?类似于等效的java代码:
import java.util.Scanner;
public class ScannerTest {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
System.out.println(sc.nextLine());
}
}
}
答案 0 :(得分:130)
最直接的方法只会使用readLine()
Predef
的一部分。然而,由于您需要检查最终的空值,这是相当丑陋的:
object ScannerTest {
def main(args: Array[String]) {
var ok = true
while (ok) {
val ln = readLine()
ok = ln != null
if (ok) println(ln)
}
}
}
这是如此冗长,你宁愿使用java.util.Scanner
。
我认为一种更漂亮的方法将使用scala.io.Source
:
object ScannerTest {
def main(args: Array[String]) {
for (ln <- io.Source.stdin.getLines) println(ln)
}
}
答案 1 :(得分:52)
对于控制台,您可以使用Console.readLine
。你可以写(如果你想停在空行上):
Iterator.continually(Console.readLine).takeWhile(_.nonEmpty).foreach(line => println("read " + line))
如果你捕获一个文件来生成输入,你可能需要使用以下命令停止空或空:
@inline def defined(line: String) = {
line != null && line.nonEmpty
}
Iterator.continually(Console.readLine).takeWhile(defined(_)).foreach(line => println("read " + line))
答案 2 :(得分:27)
val input = Source.fromInputStream(System.in);
val lines = input.getLines.collect
答案 3 :(得分:10)
答案 4 :(得分:10)
递归版本(编译器检测尾递归以改进堆使用),
def read: Unit = {
val s = scala.io.StdIn.readLine()
println(s)
if (s.isEmpty) () else read
}
请注意Scala 2.11中io.StdIn
的使用。另请注意,通过这种方法,我们可以在最终返回的集合中累积用户输入 - 除了打印输出外。即,
import annotation.tailrec
def read: Seq[String]= {
@tailrec
def reread(xs: Seq[String]): Seq[String] = {
val s = StdIn.readLine()
println(s)
if (s.isEmpty()) xs else reread(s +: xs)
}
reread(Seq[String]())
}
答案 5 :(得分:1)
正如其他评论中简要指出的,scala.Predef.readLine()
is deprecated自Scala 2.11.0起,您可以将其替换为scala.io.StdIn.readLine()
:
// Read STDIN lines until a blank one
import scala.io.StdIn.readLine
var line = ""
do {
line = readLine()
println("Read: " + line)
} while (line != "")