Scala学习九——文件和正则表达式
一.本章要点
- 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学习九——文件和正则表达式的更多相关文章
- Scala学习(九)---文件和正则表达式
文件和正则表达式 摘要: 在本篇中,你将学习如何执行常用的文件处理任务,比如从文件中读取所有行或单词,或者读取包含数字的文件等.本篇的要点包括: 1. Source.fromFile(...).get ...
- Scala学习(九)练习
文件正则表达式&练习 1. 编写一小段Scala代码,将某个文件中的行倒转顺序,将最后一行作为第一行,依此类推 程序代码: import scala.io.Source import java ...
- Scala学习笔记--文件IO
补充: http://blog.csdn.net/lyrebing/article/details/20369445 http://developer.51cto.com/art/200907/134 ...
- 初步学习pg_control文件之九
接前文,初步学习pg_control文件之八 来看这个: pg_time_t time; /* time stamp of last pg_control update */ 当初初始化的时候,是这样 ...
- 机器学习(三)--- scala学习笔记
Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...
- 【大数据】Scala学习笔记
第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java 以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...
- 【Scala】Scala学习资料
Scala学习资料 java 树形 分类器_百度搜索 决策树分类器-Java实现 - CSDN博客 KNN分类器-Java实现 - CSDN博客 学习:java设计模式—分类 - 飞翔荷兰人 - 博客 ...
- 初步学习pg_control文件之十
接前文 初步学习pg_control文件之九 看下面这个 XLogRecPtr checkPoint; /* last check point record ptr */ 看看这个pointer究竟保 ...
- Scala学习随笔——Scala起步
实验楼学习Scala语言的笔记,课程网址为https://www.shiyanlou.com/courses/490 一.Scala简介 Scala 是一门多范式的编程语言,类似于 Java .设计初 ...
随机推荐
- Leetcode题目136.只出现一次的数字(简单)
---恢复内容开始--- 题目描述: 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用额外 ...
- CSS3 新特性
~平时喜欢逛博客,看别人的学习总结和遇到的问题解决办法,恰好最近在做书签整理,翻到了之前一个前辈移动前端的总结,所以我就按他的总结模块对自己的知识进行了梳理,不过由于都是手写的,为了方便,下面的都是平 ...
- 订阅发布模式eventEmiter
// 订阅发布模式 class EventEmitter { constructor() { this._events = {}; } on(name, callback) { if (this._e ...
- 使用Python爬取mobi格式电纸书
最近做了个微信推送kindle电子书的公众号:kindle免费书库 不过目前电子书不算非常多,所以需要使用爬虫来获取足够书籍. 于是,写了以下这个爬虫,来爬取kindle114的电子书. 值得注意的地 ...
- AngularJS ng-disabled在a内无效
在AngularJS中,对a添加ng-disabled,在disabled情况下,虽显示了不可用的样式,但点击了依旧能触发绑定在a上的ng-click事件. 解决方式:将a改为button.
- 记一次ceph集群的严重故障 (转)
问题:集群状态,坏了一个盘,pg状态好像有点问题[root@ceph-1 ~]# ceph -s cluster 72f44b06-b8d3-44cc-bb8b-2048f5b4acfe ...
- memcached-slab内存管理
一.Memcache内存分配机制 关于这个机制网上有很多解释的,我个人的总结如下. Page为内存分配的最小单位. Memcached 的内存分配以page为单位,默认情况下一个page是1M,可以通 ...
- jenkins报错解决
https://www.cnblogs.com/yangxia-test/p/4368778.html https://blog.csdn.net/xlyrh/article/details/5138 ...
- SaCa DataQuality概述
1.1 产品特性 UniEAP DataQuality(以下简称DataQuality)是UniEAP最新推出的数据质量管理平台.基于数据监控服务.数据质量校验引擎.数据清洗引擎以及面向服务数据质量架 ...
- Python multiprocess模块(下)
主要内容:(参考资料) 一. 管道 二. 数据共享 数据共享是不安全的 三. 进程池 进程池的map传参 进程池的同步方法 进程池的异步方法 详解apply和apply_async apply_asy ...