zoukankan      html  css  js  c++  java
  • Scala--文件和正则表达式

    一、读取行

      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》

  • 相关阅读:
    剑指offer——72圆圈中最后剩下的数字
    剑指offer——71扑克牌中的顺子
    剑指offer——70n个骰子的点数
    剑指offer——69队列的最大值
    剑指offer——68队列的最大值
    剑指offer——67左旋转字符串
    剑指offer——66翻转字符串
    剑指offer——65和为S的连续正数序列
    「日常训练」COMMON 约数研究(HYSBZ-1968)
    「暑期训练」「基础DP」免费馅饼(HDU-1176)
  • 原文地址:https://www.cnblogs.com/one--way/p/5809527.html
Copyright © 2011-2022 走看看