任务分析
- 读入test.txt这个文件。得到一个长长的字符串:"I am studying scala. I like scala."
- 把这个字符串拆分成一个一个的单词:I, am, studying, scala .....
- 统计每个单词出现的次数
- 对结果排序(降序排列)
- 把结果输出到一个新的文件中
综合结果
object word01 {
def main(args: Array[String]) = {
val content = "I am studying scala. I like scala.";
//2. 把字符串拆分为单词
val list = content.split("\W+").map(word=>word.toLowerCase);
// 使用 正则表达式 W+ 去拆分字符串,结果是一个List
// \W 表示一个非字符(!,.,? 空格)
//list.foreach(ele => println(ele))
// 3. 统计每个单词出现的次数
// 新建一个Map("I" -> 1, "am" -> 2)
val map1 = scala.collection.mutable.Map[String,Int]()
// 对于list中的每个单词,
list.foreach(word =>{
// 检查它在Map中是否存在?
// println(word, map1.contains(word))
if(map1.contains(word)){
map1(word) += 1 // 存在: 把它的值+1
} else {
map1(word) = 1 // 不存在: 把它的值设为1
}
})
// 4. 对结果排序(降序排列)
// Map本身是无序的,它没有排序的功能
// 如果要对它的内容进行排序,那么,我们要把它转换成可以排序的集合:List
// sortBy: 排序:根据元组的第二个值
// reverse: 翻转
val wordList = map1.toList.sortBy(_._2).reverse
// 5. 把结果输出到一个新的文件中
val fileWriter = new FileWriter("result.txt")
wordList.foreach(el => {
fileWriter.write(s"${el._1} - ${el._2} \n")
})
fileWriter.close()
}
}
代码说明
从文件中读出内容
在scala中,涉及到文件读写的方法有很多,可以使用java.io下的工具包,也可以使用scala.io下的功能
格式:scala.io.Source.formFile(文件名)
作用:读入一个文件
import scala.io.Source
val content = Source.fromFile("example.txt").mkString
println(content)
写拆分单词统计个数
分析每个单词的个数
1. 分隔出一个一个的单词。
2. 建立一个Map,key是单词,value是次数。
3. 遍历所有的单词,对每个单词来说:判断单词是否存在,如果存在把对应的key+1;否则就设置对应的key,且value为1
val words = inputString.split("\\W+")
val wordCountMap = mutable.Map[String, Int]()
for (word <- words) {
if (wordCountMap.contains(word)) {
wordCountMap(word) += 1
} else {
wordCountMap(word) = 1
}
}
\\W+,表示一个非字符。
对Map结果排序
Map本身是键值对,它是无序的。可以先转成List或者Seq,然后再排序
wordCountMap.toSeq.sortBy(_._2).foreach(str=>{
println(s"${str._1}: ${str._2}")
})
结果写入
使用java.io.PrintWriter写入文件的示例
import java.io.PrintWriter
object PrintWriterExample {
def main(args: Array[String]) {
val writer = new PrintWriter("output.txt")
writer.write("Hello, Scala PrintWriter!")
writer.close()
}}