scala 读取txt文件的方法示例

网友投稿 598 2023-08-03

scala 读取txt文件的方法示例

scala 读取txt文件的方法示例

文件格式分别如下

package txt

object ReadTxt {

def rdcvRcaYBieadFromTxtByLine(filePath:String) = {

//导入Scala的IO包

import scala.io.Source

//以指定的UTF-8字符集读取文件,第一个参数可以是字符串或者是java.io.File

val source = Source.fromFile(filePath, "UTF-8")

//或取文件中所有行

//val lineIterator = source.getLines()

//迭代打印所有行

//lineIterator.foreach()

//将所有行放到数组中

val lines = source.getLines().toArray

source.close()

//println(lines.size)

lines

}

def LackingFileUtil(array:Array[String],keyMap:Map[String,String]) = {

// 使用for循环和until遍历Array / ArrayBuffer

// 使until是RichInt提供的函数

var lockMapList = List[Map[String,String]]()

for (i <- 0 until array.length){

if(i==0){

val lineArray = array(i).trim.split("\\|")

lockMapList = lockMapList :+ Map("id"->lineArray(0).trim,"name"->lineArray(1).trim,"pass"->lineArray(2).trim)

}else{

val lineArray = array(i).split(",")

if(lineArray.length==3){

lockMapList = lockMapList :+ Map("id"->lineArray(0).trim,"name"->lineArray(1).trim,"pass"->lineArray(2).trim)

}else if(lineArray.length==2){

val pass = keyMap.getOrElse(lineArray(0).trim,lineArray(1).trim)

lockMapList = lockMapList :+ MdcvRcaYBiap("id"->lineArray(0).trim,"name"->lineArray(1).trim,"pass"->pass.trim)

}else if(lineArray.length==1){

lockMapList = lockMapList :+ Map("id"->lineArray(0).trim,"name"->"","pass"->"")

}else{

lockMapList = lockMapList :+ Map("id"->"-","name"->"","pass"->"")

}

}

//println(array(i))

}

lockMapList

// 跳跃遍历Array / ArrayBuffer

/*for(i <- 0 until (array.length, 2))

println(array(i))*/

// 从尾部遍历Array / ArrayBuffer

/*for(i <- (0 until array.length).reverse)

println(array(i))*/

// 使用“增强for循环”遍历Array / ArrayBuffer

/*for (e <- array){

println(e)

e.split(",").mkString

}*/

}

def KeyFileUtil(array:Array[String]) = {

var keyMapList = Map[String, String]()

for (i <- 0 until array.length) {

//println(array(i))

val lineArray = array(i).trim.split(",")

//println(lineArray.size)

if(lineArray.size==2){

keyMapList = keyMapList ++ Map(lineArray(0).trim -> lineArray(1).trim)

}else if(lineArray.size==1){

keyMapList = keyMapList ++ Map(lineArray(0).trim -> "")

}else{

keyMapList = keyMapList ++ Map("-" -> "")

}

}

keyMapList

}

def isEmpty(s: String): Boolean = (s == null) || (s.size==0)

}

package txt

import scala.reflect.io.File

object App {

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

val key = ReadTxt.readFromTxtByLine("D:"+File.separator+"workspace"+File.separator+"source.txt")

//println(key.mkString)

val keyMap = ReadTxt.KeyFileUtil(key)

//println(keyMap)

val lack = ReadTxt.readFromTxtByLine("D:"+File.separator+"workspace"+File.separator+"source1.txt")

val lockMapList = Reahttp://dTxt.LackingFileUtil(lack,keyMap)

println(lockMapList)

}

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:scala 操作数据库的方法
下一篇:JVM的类加载过程以及双亲委派模型详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~