欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用kotlin實(shí)現(xiàn)統(tǒng)計(jì)文件字符個(gè)數(shù)的方法示例

 更新時(shí)間:2017年12月03日 10:12:47   作者:厚土火焰山  
最近在學(xué)習(xí)kotlin,發(fā)現(xiàn)了一些不錯(cuò)的小技巧,所以下面這篇文章主要給大家介紹了關(guān)于利用kotlin實(shí)現(xiàn)統(tǒng)計(jì)文件字符個(gè)數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

對(duì)于開發(fā)的大家來說,統(tǒng)計(jì)文件字符個(gè)數(shù)是個(gè)常見的程序。今天利用剛學(xué)習(xí)的kotlin來實(shí)現(xiàn)一下。下面話不多說了,來一起看看詳細(xì)的介紹吧。

方法如下:

首先找到一個(gè)要統(tǒng)計(jì)的文件。

val file = "F:\\MyBook\\讀書備忘錄.txt"

然后建立一個(gè)HashMap,用來存儲(chǔ)統(tǒng)計(jì)的結(jié)果。

val map = HashMap<Char, Int>()

讀取文件內(nèi)容,轉(zhuǎn)換成Char進(jìn)行遍歷統(tǒng)計(jì)

File(file).readText().toCharArray().filterNot(Char::isWhitespace).forEach {
  val count = map[it]
  if (count == null){
   map[it] = 1
  }else{
   map[it] = count +1
  }  
 }

readText()就是讀取文件內(nèi)容了

toCharArray()轉(zhuǎn)成Char數(shù)組

filterNot(Char::isWhitespace)忽略空格

遍歷的時(shí)候,把當(dāng)前遍歷到的map[it]賦給 count ,如果在 map 中沒找到這個(gè)字符,即 count == null,則為初次記錄,map[it] 為1,否則 map[it] 已經(jīng)記錄過了,在原有計(jì)數(shù)基礎(chǔ)上加1。

最后輸出統(tǒng)計(jì)結(jié)果

map.forEach { t, u -> println("字符\"$t\"出現(xiàn)了 $u 次")}

執(zhí)行效果如下

統(tǒng)計(jì)文件中每個(gè)字符的個(gè)數(shù)
字符"言"出現(xiàn)了 1 次
字符"需"出現(xiàn)了 1 次
字符"最"出現(xiàn)了 1 次
字符"要"出現(xiàn)了 1 次
字符"節(jié)"出現(xiàn)了 1 次
字符"。"出現(xiàn)了 1 次
字符"窄"出現(xiàn)了 1 次
字符"的"出現(xiàn)了 1 次
字符"★"出現(xiàn)了 5 次
字符"("出現(xiàn)了 1 次
字符"按"出現(xiàn)了 1 次
字符")"出現(xiàn)了 1 次
字符"《"出現(xiàn)了 1 次
字符"》"出現(xiàn)了 1 次
字符","出現(xiàn)了 2 次
字符"完"出現(xiàn)了 1 次
字符"復(fù)"出現(xiàn)了 1 次
字符"后"出現(xiàn)了 2 次
字符"題"出現(xiàn)了 1 次
字符":"出現(xiàn)了 1 次
字符"圣"出現(xiàn)了 1 次
字符"個(gè)"出現(xiàn)了 1 次
字符"本"出現(xiàn)了 1 次
字符"-"出現(xiàn)了 2 次
字符"."出現(xiàn)了 2 次
字符"0"出現(xiàn)了 4 次
字符"新"出現(xiàn)了 1 次
字符"1"出現(xiàn)了 6 次
字符"2"出現(xiàn)了 3 次
字符"3"出現(xiàn)了 2 次
字符"6"出現(xiàn)了 3 次
字符"邊"出現(xiàn)了 1 次
字符"雅"出現(xiàn)了 1 次
字符"G"出現(xiàn)了 1 次
字符"版"出現(xiàn)了 1 次
字符"重"出現(xiàn)了 1 次
字符"經(jīng)"出現(xiàn)了 1 次
字符"黑"出現(xiàn)了 1 次
字符"體"出現(xiàn)了 1 次
字符"字"出現(xiàn)了 1 次
字符"這"出現(xiàn)了 1 次
字符"距"出現(xiàn)了 1 次
字符"章"出現(xiàn)了 1 次
字符"習(xí)"出現(xiàn)了 2 次
字符"d"出現(xiàn)了 1 次
字符"f"出現(xiàn)了 1 次
字符"學(xué)"出現(xiàn)了 1 次
字符"書"出現(xiàn)了 1 次
字符"照"出現(xiàn)了 1 次
字符"全"出現(xiàn)了 1 次
字符"語(yǔ)"出現(xiàn)了 1 次
字符"o"出現(xiàn)了 1 次
字符"p"出現(xiàn)了 1 次
字符"數(shù)"出現(xiàn)了 1 次
字符"讀"出現(xiàn)了 1 次

上面的讀取還不夠簡(jiǎn)練,我們可以再簡(jiǎn)化一點(diǎn),完全不必聲明 HashMap。

val file = "F:\\MyBook\\讀書備忘錄.txt"
File(file).readText().toCharArray().filterNot(Char::isWhitespace).groupBy{it}.map {
  it.key to it.value.size
 }.forEach{
  println("字符\"${it.first}\"出現(xiàn)了 ${it.second} 次")
 }

一樣可以達(dá)到效果。這才是函數(shù)式編程。

附上:HashMap結(jié)構(gòu)圖

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

最新評(píng)論