1. 程式人生 > >scala當中的文件操作和網絡請求

scala當中的文件操作和網絡請求

file save -c leo clas puts spa 網絡請求 lin

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("\t"))

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當中的文件操作和網絡請求