scala当中的文件操作和网络请求

Posted starzy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了scala当中的文件操作和网络请求相关的知识,希望对你有一定的参考价值。

1、读取文件当中每一行的数据

def main(args: Array[String]): Unit = {

//注意文件的编码格式,如果编码格式不对,那么读取报错

val file: BufferedSource = Source.fromFile("F:\files\file.txt","GBK");

val lines: Iterator[String] = file.getLines()

for(line <- lines){

println(line)

}

//注意关闭文件

file.close()

}

如果要将文件内容转数组,直接调用toArray即可

? ?

2、读取词法单元和数字

如果想将以某个字符或某个正则表达式分开的字符成组读取,可以这么做:

def main(args: Array[String]): Unit = {

val file: BufferedSource = Source.fromFile("F:\files\file2.txt","GBK");

val split: Array[String] = file.mkString.split(" ")

println(split.mkString(" "))

file.close()

}

? ?

3、读取网络资源、文件写入、控制台操作

1、读取网络资源

def main(args: Array[String]): Unit = {

val source: BufferedSource = Source.fromURL("http://www.baidu.com")

val string: String = source.mkString

? ?

println(string)

source.close()

}

2、文件写入操作

def main(args: Array[String]): Unit = {

val writer = new PrintWriter("F:files\printWriter.txt")

for(i <- 1 to 100){

writer.println(i)

writer.flush()

}

writer.close()

}

?

3、控制台交互操作

def main(args: Array[String]): Unit = {

//控制台交互--API

print("请输入内容:")

val consoleLine1 = Console.readLine()

println("刚才输入的内容是:" + consoleLine1)

? ?

//控制台交互--API

print("请输入内容(API):")

val consoleLine2 = StdIn.readLine()

println("刚才输入的内容是:" + consoleLine2)

}

? ?

4、scala当中的序列化

@SerialVersionUID(1L)

class Person extends Serializable{

override def toString = name + "," + age

? ?

val name = "Nick"

val age = 20

? ?

}

? ?

object PersonMain extends App{

override def main(args: Array[String]): Unit = {

? ?

import java.io.{FileOutputStream, FileInputStream, ObjectOutputStream, ObjectInputStream}

val nick = new Person

val out = new ObjectOutputStream(new FileOutputStream("Nick.obj"))

out.writeObject(nick)

out.close()

? ?

val in = new ObjectInputStream(new FileInputStream("Nick.obj"))

val saveNick = in.readObject()

in.close()

println(saveNick)

}

}

? ?

5、scala当中的正则表达式

我们可以通过正则表达式匹配一个句子中所有符合匹配的内容,并输出:

? ?

def main(args: Array[String]): Unit = {

import scala.util.matching.Regex

val pattern1 = new Regex("(S|s)cala")

val pattern2 = "(S|s)cala".r

val str = "Scala is scalable and cool"

println((pattern2 findAllIn str).mkString(","))

}

?

以上是关于scala当中的文件操作和网络请求的主要内容,如果未能解决你的问题,请参考以下文章

scala过滤操作过滤CSV文件

09-文件和网络请求

NFS网络文件系统安装与测试

PHP下载文件

Scala的文件操作

[原创]Scala学习:Tuple,Array,Map ,文件操作