一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - scala 讀取txt文件的方法示例

scala 讀取txt文件的方法示例

2019-06-29 16:30張樂1993 Java教程

這篇文章主要介紹了scala 讀取txt文件的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

文件格式分別如下

 scala 讀取txt文件的方法示例  

scala 讀取txt文件的方法示例

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)
 
 
 }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: avtt在线播放 | 免费黄色片网站 | a黄毛片| 好湿好紧太硬了我太爽了h 好湿好滑好硬好爽好深视频 | 日韩a无吗一区二区三区 | www.爱情岛论坛| 国产精品亚洲专区一区 | 欧美又硬又粗又长又大 | 国内老司机精品视频在线播出 | 亚洲精品午夜视频 | 免费高清在线视频色yeye | 91国内精品久久久久怡红院 | 处女摘花视频 | 粉嫩高中生第一次不戴套 | 欧美成人第一页 | www红色一片在线观看版 | 国产一区二区三区四卡 | haodiaocao的视频这里看 | 国产卡一卡二卡3卡乱码免费 | 高h射尿| 九九精品视频在线观看九九 | 亚洲ⅴa偷拍在线影院 | 四虎永久在线精品免费影视 | 国产激情视频网站 | 香蕉久久久久久狠狠色 | 操岳母逼小说 | 俺去俺去啦最新官网在线 | 日韩精品一区二区三区毛片 | 精品亚洲一区二区三区在线播放 | 亚洲国内精品 | 美女被灌浣肠失禁视频 | 国产成人青草视频 | 久久AV喷吹AV高潮欧美 | 全肉一女n男np高h乳 | 亚洲一级片在线播放 | 国产无套在线播放 | 国产51 | 久久久免费观成人影院 | 91porny丨首页 | 成年私人影院免费视频网站 | 日本 片 成人 在线 日b视频免费 |