Scala学习笔记--文件IO
补充:
http://blog.csdn.net/lyrebing/article/details/20369445
http://developer.51cto.com/art/200907/134957.htm
http://nerd-is.in/2013-08/scala-learning-files-and-regular-expressions/
读取行
//读取文件中的所有行,可以调用scala.io.Source对象的getLines方法
object LineIO{
def main(args:Array[String]):Unit = {
val source = Source.fromFile("F:\\way.txt","UTF-8")
//第一个参数可以是字符串或者是java.io.File
//第二个参数可省略
val lineIterator =source.getLines
//结果是一个迭代器 for(l<-lineIterator)
println(l)
//或者可以对迭代器应用toArray或toBuffer方法,将行放到数组或数组缓冲当中
val lines = source.getLines.toArray
//将整个文件读取成一个字符串
//val contents = source.mkString;
source.close
}
}
读取字符(一个一个字符处理)
//按字符处理
object CharIO{
def main(args:Array[String]):Unit={
val source =Source.fromFile("F:\\way.txt","UTF-8")
val iter= source.buffered
//println(iter.length)
while(iter.hasNext){
print(iter.next.toString)
}
source.close
}
}
读取词法单元和数字
object NumIO{
def main(args:Array[String]):Unit={
val source = Source.fromFile("F:\\num.txt","UTF-8")
val tockens = source.mkString.split(" ")
for(w<-tockens){
println(w.toInt)
}
//另一种方法
val numbers = for(w<-tockens)
yield w.toDouble
for(num<-numbers){
println(num)
} //另一种方法
val numbers2 = tockens.map(_.toDouble)
}
}
从URL或其他源读取
//读取非文件源的方法
object URLIO{
def main(args:Array[String]):Unit={
//从URL读取
val source= Source.fromURL("http://www.baidu.com","UTF-8")
val lineIterator =source.getLines
for(l<-lineIterator){
println(l.toString())
} //从给定的字符串读取--调试有用
val source2= Source.fromString("Hello world") //从标准输入读取
val source3 = Source.stdin
}
}
运行结果为网址的html
读取二进制文件
Scala没有提供读取二进制文件的方法,需要使用Java类库
object URLIO{
def main(args:Array[String]):Unit={
val file = new File("F:\\info.bin")
val in = new FileInputStream(file)
val bytes = new Array[Byte](file.length.toInt)
in.read(bytes)
in.close
}
}
写入文本文件
object WriteIO{
def main(args:Array[String]):Unit={
val out = new PrintWriter("F:\\numbers.txt")
for(i<-1 to 100)
out.println(i)
out.close
}
}
Scala学习笔记--文件IO的更多相关文章
- Java学习笔记--文件IO
简介 对于任何程序设计语言,输入和输出(Input\Output)都是系统非常核心的功能,程序运行需要数据,而数据的获取往往需要跟外部系统进行通信,外部系统可能是文件.数据库.其他程序.网络.IO设备 ...
- 基于.net的分布式系统限流组件 C# DataGridView绑定List对象时,利用BindingList来实现增删查改 .net中ThreadPool与Task的认识总结 C# 排序技术研究与对比 基于.net的通用内存缓存模型组件 Scala学习笔记:重要语法特性
基于.net的分布式系统限流组件 在互联网应用中,流量洪峰是常有的事情.在应对流量洪峰时,通用的处理模式一般有排队.限流,这样可以非常直接有效的保护系统,防止系统被打爆.另外,通过限流技术手段,可 ...
- 《python基础教程(第二版)》学习笔记 文件和素材(第11章)
<python基础教程(第二版)>学习笔记 文件和素材(第11章) 打开文件:open(filename[,mode[,buffering]]) mode是读写文件的模式f=open(r' ...
- Scala学习笔记及与Java不同之处总结-从Java开发者角度
Scala与Java具有很多相似之处,但又有很多不同.这里主要从一个Java开发者的角度,总结在使用Scala的过程中所面临的一些思维转变. 这里仅仅是总结了部分两种语言在开发过程中的不同,以后会陆续 ...
- 【大数据】Scala学习笔记
第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java 以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...
- Scala学习笔记之:tuple、array、Map
[TOC] 本文<快学Scala>的笔记 tuple学习笔记 tuple的定义 对偶是元组(tuple)的最简单形态--元组是不同类型的值的聚集. 元组的值是通过将单个值包含在圆括号中构成 ...
- 机器学习(三)--- scala学习笔记
Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...
- java学习笔记之IO编程—内存流、管道流、随机流
1.内存操作流 之前学习的IO操作输入和输出都是从文件中来的,当然,也可以将输入和输出的位置设置在内存上,这就需要用到内存操作流,java提供两类内存操作流 字节内存操作流:ByteArrayOutp ...
- [Python学习笔记]文件的读取写入
文件与文件路径 路径合成 os.path.join() 在Windows上,路径中以倒斜杠作为文件夹之间的分隔符,Linux或OS X中则是正斜杠.如果想要程序正确运行于所有操作系统上,就必须要处理这 ...
随机推荐
- Android Activity整体管理和关闭工具类封装
如何彻底退出程序,在任意位置退出程序,如何管理当前的运行栈,知道activity的堆栈结构等,本文封装了一个Activity管理类,可以方便随时退出程序. /** * 应用程序Activity管理类: ...
- 总结:man, info, hwclock, cal, type, which, dirname, basename, who, which, whatis, makewhatis, hash, tty
man, info, help, date, hwclock, cal, shutdown, reboot, halt, poweroff, type, cd, which, dirname, bas ...
- Http请求工具实例编写
HTTP协议工作方式首先客户端发送一个请求(request)给服务器,服务器在接收到这个请求后将生成一个响应(response)返回给客户端.在这个通信的过程中HTTP协议在以下4个方面做了规定:1. ...
- Nginx学习之六-nginx核心进程模型
一.Nginx整体架构 正常执行中的nginx会有多个进程,最基本的有master process(监控进程,也叫做主进程)和woker process(工作进程),还可能有cache相关进程. 一个 ...
- hdu 1253 胜利大逃亡 (三维简单bfs+剪枝)
胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Subm ...
- MC, MCMC, Gibbs採样 原理&实现(in R)
本文用讲一下指定分布的随机抽样方法:MC(Monte Carlo), MC(Markov Chain), MCMC(Markov Chain Monte Carlo)的基本原理,并用R语言实现了几个样 ...
- HDU4662+无
把目标中的 U 转化为 I. 又因为 I的个数是有规律的:1 2 4 8 16 ...再结合可以取消 6 12 18 ...个I...得解 #include<string.h> #incl ...
- android repo库的创建及代码管理
- UI Prototype Design IDE( 界面原型设计工具 )
UI Prototype Design IDE( 界面原型设计工具 ) 如何用工具去与客户进行交流,互动,定义要做的系统,什么什么的... 0.Balsamiq Mockups http://ww ...
- [SVG] Simple introduce for SVG
Just like create html page, you can create a svg tag by: <?xml version="1.0" encoding=& ...