一.本章要点

  • Source.fromFile(...).getLines.toArray输出文件的所有行;
  • Source.fromFile(...).mkString以字符串形式输出文件内容;
  • 将字符串转换为数字,可以用toInt或toDouble方法;
  • 使用Java的PrintWriter来写入文件;
  • ”正则“.r是一个Regex对象;
  • 如果你的正则表达式包含反斜杠或引号的话,用”“”...“”“;
  • 如果正则模式包含分组,你可以用如下语法提取内容:for(regex(变量1,...,变量n)<-字符串)

二.读取行

  注:用完Source对象后,记得close

import scala.io.Source
//第一个参数可以是字符串或者java.io.File
//如果你知道文件使用的是当前平台缺省的代码,可以省略第二个参数
val source=Source.fromFile("myFile.txt","UTF-8")
//返回的是一个迭代器
val lineIterator=source.getLines
//可以逐行获取
for(l<-lineIteraor) ...
//可以放到数组(toarray)或数组缓冲(toBuffer)
val lines=source.getLines.toArray
//读取成一个字符串
val contents=source.mkString

三.读取字符

  1.直接把Source对象当作迭代器(Source类扩展于Iterator[Char],例:for(c<-Source)...),想要查看某个字符又不处理它(调用source对象的buffered方法,用head方法查看下一个字符又不处理,相当于Java的PushbackInoutStreamReader);

  2.文件不大,可以直接读取到一个字符串中

四.读取词法单元和数字

  快而脏读取词法单元,以空格隔开:val tokens=source.mkString.split("\\S+")

  读取到数组val numbers=for(w<-token) yield w.toDouble或者val numbers=tokens.map(_.toDouble)  

五.从URL或其他源读取

//从URL读取时需要事先知道字符集
val sources1=Source.fromURL("http://horstman.com","UTF-8")
//从给定的字符串读取,对调试很有用
val source2=Source.fromString("Hello,World")
//从标准输入读取数
val source3=Source.stdin

六.读取二进制文件

  Scala没有提供,需要使用Java类库

val file=new File(filename)
val in=new FileInoutStream(file)
val byte=new Array[Byte](file.length.toInt)
in.read(bytes)
in.close()

七.写入文本文件

  Scala没有内建的对写入文件的支持,需要用java.io.PrintWrite

val out=new PrintWriter("numbers.txt")
for(i<- 1 to 100)
//如果是使用printf会提示把它转换为AnyRef
out.println(i)
out.close()

八.访问目录

  Scala也没有提供正式的访问目录中的所有文件的方法:

  

import java.io.File
def subdirs(dir:File):Iterator[File]={
val children=dir.listFiles.filter(_.isDirectory)
children.toIterator++children.toIterator.flatMap(subdirs _) } for(d<-subdirs(dir))...

  Java7中还有walkFileTree方法可行

九.序列化

  利用序列化将对象传输到其他虚拟机或临时存储。

val fred = new Person(...)
import java.io._
val out=new ObjectOutputSteam(new FileOutputStream("...."))
out.writeObject(fred)
out.close()
val in=new ObjectInputStream(new FileInputStream("..."))
val savedFred=in.readObject().asInstanceof(Person)
//Scala集合类是可序列化的 class Person extends Serializable{
private val friends=new ArrayBuffer[Person] }

十.进程控制

  scala.sys.process提供了与shell交互的工具,scala.sys包含了一个从字符串到ProcessBuilder对象的隐式转换(!执行的就是这个,成功执行程序返回0,否则非0;!!以字符串形式返回;#>输出重定向;#>>追加;#<把某个文件内容作为输入;管道符#|......#||;#&&等等)

  可以使用Process对象的apply方法构造ProcessBuilder,然后执行。 

十一.正则表达式

  使用scala.util.matching.Regex使用正则表达式分析,使用String类的r方法构建Regex对象。

  如果正则表达式包含反斜杠或引号,最好使用"""...""",例:val wsnumsPattern="""\s+[0,9]\s+""".r,比"\\s+[0,9]+\\s+"更易读。

  findAllIn方法返回遍历所有匹配项的迭代器(可以用for遍历),也可以将迭代器转成数组.......还有findFirstIn(首个匹配项,得到Option),findPrefixOf(检查是否某个字符串的开始部分能匹配),replaceFirstIN(替换首个),replaceAllIn(替换所有)。

十二.正则表达式组

  分组让我们更方便的获取正则表达式的子表达式,想要获取的子表达式加()即可,如:val numPattern="([0-9]+)([a-z]+)".r,还可以当做提取器val numPattern(num,item)="...."。

十三.练习

  

Scala学习九——文件和正则表达式的更多相关文章

  1. Scala学习(九)---文件和正则表达式

    文件和正则表达式 摘要: 在本篇中,你将学习如何执行常用的文件处理任务,比如从文件中读取所有行或单词,或者读取包含数字的文件等.本篇的要点包括: 1. Source.fromFile(...).get ...

  2. Scala学习(九)练习

    文件正则表达式&练习 1. 编写一小段Scala代码,将某个文件中的行倒转顺序,将最后一行作为第一行,依此类推 程序代码: import scala.io.Source import java ...

  3. Scala学习笔记--文件IO

    补充: http://blog.csdn.net/lyrebing/article/details/20369445 http://developer.51cto.com/art/200907/134 ...

  4. 初步学习pg_control文件之九

    接前文,初步学习pg_control文件之八 来看这个: pg_time_t time; /* time stamp of last pg_control update */ 当初初始化的时候,是这样 ...

  5. 机器学习(三)--- scala学习笔记

    Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...

  6. 【大数据】Scala学习笔记

    第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java  以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...

  7. 【Scala】Scala学习资料

    Scala学习资料 java 树形 分类器_百度搜索 决策树分类器-Java实现 - CSDN博客 KNN分类器-Java实现 - CSDN博客 学习:java设计模式—分类 - 飞翔荷兰人 - 博客 ...

  8. 初步学习pg_control文件之十

    接前文 初步学习pg_control文件之九 看下面这个 XLogRecPtr checkPoint; /* last check point record ptr */ 看看这个pointer究竟保 ...

  9. Scala学习随笔——Scala起步

    实验楼学习Scala语言的笔记,课程网址为https://www.shiyanlou.com/courses/490 一.Scala简介 Scala 是一门多范式的编程语言,类似于 Java .设计初 ...

随机推荐

  1. LeetCode 76. 最小覆盖子串(Minimum Window Substring)

    题目描述 给定一个字符串 S 和一个字符串 T,请在 S 中找出包含 T 所有字母的最小子串. 示例: 输入: S = "ADOBECODEBANC", T = "ABC ...

  2. IDEA 运行单元测试报错 @{argLine}

    sentinel是今年阿里开源的高可用防护的流量管理框架. git地址:https://github.com/alibaba/Sentinel wiki:https://github.com/alib ...

  3. LC 980. Unique Paths III

    On a 2-dimensional grid, there are 4 types of squares: 1 represents the starting square.  There is e ...

  4. js获取后台传给前台的值

    1.后台传给前台的方法 String rulemodeid=req.getParameter("rulemodeid"); req.setAttribute("rulem ...

  5. How To Install OpenSSL on Windows

    转自 https://tecadmin.net/install-openssl-on-windows/ OpenSSL is a full-featured toolkit for the Trans ...

  6. 小D课堂 - 新版本微服务springcloud+Docker教程_6-04 自定义Zuul过滤器实现登录

    笔记 4.自定义Zuul过滤器实现登录鉴权实战     简介:自定义Zuul过滤器实现登录鉴权实战 1.新建一个filter包 2.新建一个类,实现ZuulFilter,重写里面的方法 3.在类顶部加 ...

  7. Kafka offset机制

  8. mysql千万级数据表结构修改

    当需要对表进行ddl操作如加索引.增删列时,数据量小时直接在线修改表结构影响不大当表达到百万.千万数据就不能直接在线修改表结构 下面是具体的过程:1.备份数据select * from ih_orde ...

  9. 同步pod容器内时区

    同步pod容器内时区 .直接修改镜像的时间设置,好处是应用部署时无需做特殊设置,但是需要手动构建Docker镜像. .部署应用时,单独读取主机的“/etc/localtime”文件,即创建pod时同步 ...

  10. 使用robotframework做接口测试5——一个用例中调多个接口

    凡是涉及一点点有接口关联的,都可能下一个接口需要上一个接口的某个返回值作为入参,最直接的例子,就是登录依赖.用接口做业务性的测试,也绝对离不开接口依赖的,业务都是一系列接口串联的结果,有时候一个接口操 ...