如何逐行读取标准输入?

时间:2011-01-03 15:18:18

标签: java scala io java.util.scanner

从标准输入逐行阅读的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());
        }
    }
}

6 个答案:

答案 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)

你能否使用

var userinput = readInt // for integers
var userinput = readLine 
...

可在此处获取:Scaladoc API

答案 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 != "")