scala 读取txt文件的方法示例

文件格式分别如下 package txtobject ReadTxt {def readFromTxtByLine(filePath:String) =

文件格式分别如下

   

package txt
 
object ReadTxt {
 
 def readFromTxtByLine(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 :+ Map("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 = ReadTxt.LackingFileUtil(lack,keyMap)
 
 println(lockMapList)
 
 
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好代码网。

您可能有感兴趣的文章
IDEA 2020.3.X 创建scala环境的详细好代码教程

Scala中Array和List的区别说明

Scala求和示例代码

IntelliJ IDEA安装scala插件并创建scala工程的步骤详细好代码教程

Scala常用List列表操作方法示例