One-Way
爱一人,攀一山,追一梦

一、读取行

  import scala.io.Source

  val source = Source.fromFile("D:\\documents\\Scala\\MyDemo\\t.txt", "UTF-8")
  
  val lineIterator = source.getLines() //获取文件行的迭代器
  for(l <- lineIterator){
    println(l)
  }

  val array = source.getLines().toArray  //把行放到Array中
  for(l <- array){
    println(l)
  }
  
  val context = source.mkString //把整个文件读取成一个字符串
  println(context)
  
  source.close()

读取文件这里不能重复读取,只显示一遍文本内容

111111111
22222222222222222
3333333333

 

二、读取字符

  import scala.io.Source

  val source = Source.fromFile("D:\\documents\\Scala\\MyDemo\\t.txt","UTF-8")

  for(c <- source){  //一个字符一个字符迭代 Source扩展自 Iterator[Char]
    print(c)
  }

  val iter = source.buffered //使用bufferd方法,用head获取字符

  while(iter.hasNext){
    if(iter.head == 'a'){
      iter.next()
      iter.next()
      print(iter.head)
    }
    else{
      iter.next()
    }
  }

 

三、读取词法单元和数字

 

  import scala.io.Source
  val source = Source.fromFile("D:\\sxt\\documents\\Scala\\MyDemo\\num.txt", "gbk")
  val lines = source.getLines() //以行读取

  for(l<- lines){
    val tokens = l.split("\\s+") //将每行数据以空格隔开
    for(i<- tokens){
      print(i+",")
    }; println()

    val numbers = tokens.map(_.toDouble) //将分割的字符串转换成double类型
    for(n<- numbers){
      print(n+"|")
    }; println()

    val numbers1 = for(n<- tokens) yield n.toDouble  //将分割的字符串转换成double类型
    for(n <- numbers1){
      print(n+"-")
    }; println()

  }

 

四、从URL或其他源读取

  import scala.io.Source
  val source1 = Source.fromURL("http://www.baidu.com","UTF-8")
  println(source1)
  val source2 = Source.fromString("Hello World")
  println(source2.mkString)
  val source3 = Source.stdin
  println(source3.mkString)

 

 

五、读取二进制文件

Scala没有读取二进制文件的方法,需要使用Java类库,

  import java.io.File
  val file = new File("D:\\\\sxt\\\\documents\\\\Scala\\\\MyDemo\\\\t.txt")
  val in = new FileInputStream(file)
  val bytes = new Array[Byte](file.length.toInt)

  in.read(bytes)

  for(i <- 0 until bytes.length) print(bytes(i))

  in.close()

结果:

文件内容:abcd
输出结果:979899100

 

六、写入文本文件

  val value = 100
  val out = new PrintWriter("t1.txt")
  for(i <- 0 to 100) out.println(i)
  out.printf("%d ", value.asInstanceOf[AnyRef]) //格式化输出需要转换成 AnyRef
  out.print("%d".format(value)) //通过String的format的方法完成格式化输出
  out.close()

结果:

在项目工程目录下,生成t1.txt文件

 

七、访问目录

 

 

 

八、序列化

 

 

九、进程控制

 

 

十、正则表达式

  val numPattern = "[0-9]+".r  //通过 String的 r方法

  val wsnumwsPattern = """\s+[0-9]+\s+""".r  //"""...""" 原始字符串可包含反斜线或引号,不需要转义 "\\s+[0-9]+\\s+"

  for(matchString <- numPattern.findAllIn("99 apples, 87 bottles")) println(matchString) //findAllIn返回所有匹配项的迭代器

  val matches = numPattern.findAllIn("99 apples, 87 bottles").toArray //转换成数组
  for(m<- matches) println(m)
  
  val m1: Option[String] = wsnumwsPattern.findFirstIn("99 apples, 87 bottles") //获得第一个匹配项
  println(m1)

  val mp = numPattern.findPrefixOf("99 apples, 87 bottles")   //获取开始部分匹配的
  println(mp)

  val wsmp = wsnumwsPattern.findPrefixOf("99 apples, 87 bottles")   //获取开始部分匹配
  println(wsmp)


  val rm = numPattern.replaceAllIn("99 apples, 87 bottles","xx")   //替换所有匹配的项
  println(rm)

  val rmf = numPattern.replaceFirstIn("99 apples, 87 bottles","xx") //替换第一个匹配的项
  println(rmf)

结果:

99
87
99
87
Some( 87 )
Some(99)
None
xx apples, xx bottles
xx apples, 87 bottles

 

十一、正则表达式组

  val numitemPattern = "([0-9]+) ([a-z]+)".r  //通过()区分开,多个子表达式

  val numitemPattern(num, item) = "99 apples"   //单个匹配
  println(num,item)

  for(numitemPattern(num, item)<- numitemPattern.findAllIn("99 apples, 87 bottles")){//多个匹配项提取分组内容
    println(num,item)
  }

结果

(99,apples)
(99,apples)
(87,bottles)

 

 

参考《快学Scala》

posted on 2016-08-26 10:58  单行道|  阅读(3488)  评论(0编辑  收藏  举报