一.本章要点
- 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)="...."。
十三.练习