利用shell腳本遍歷文件夾內(nèi)所有的文件并作整理統(tǒng)計的方法
環(huán)境: Ubuntu下采用shell腳本實現(xiàn)
案例簡述: 文件夾內(nèi)有許多子文件夾,這里需要自動讀取所有的文件,包括他們的地址和文件名。通過觀察文件名的規(guī)律,按照一定的規(guī)則裁剪出文件名的某一部分,該部分為數(shù)字,則根據(jù)數(shù)字的大小統(tǒng)計該文件夾內(nèi)文件在各個數(shù)據(jù)段的數(shù)量。
1.這里寫一個函數(shù),實現(xiàn)對文件夾內(nèi)所有文件名的讀取,采用的方法是遞歸!
#!/bin/bash #folder="./test" function readfile () { #這里`為esc下面的按鍵符號 for file in `ls $1` do #這里的-d表示是一個directory,即目錄/子文件夾 if [ -d $1"/"$file ] then #如果子文件夾則遞歸 readfile $1"/"$file else #否則就能夠讀取該文件的地址 echo $1"/"$file #讀取該文件的文件名,basename是提取文件名的關鍵字 echo `basename $file` fi done } #函數(shù)定義結(jié)束,這里用來運行函數(shù) folder="./test" readfile $folder
2.這里實驗了初始化變量和變量賦值
#!/bin/bash a=002 #打印a的值 echo $a #注意這里賦初始值不能有空格 b=20 c=30 #注意這里[]和符號及字母之間一定要有空格,否則錯誤! #這里shell腳本的邏輯運算-a表示與運算,-o表示或運算,!表示否運算 #-lt表示小于,-gt表示大于,-eq表示等于,-ne表示不等于,-le表示小于等于,-ge表示大于等于 if [ $a -lt $b -a $a -gt $c ] then #這里賦值注意兩個括號,等號兩邊不能留有空隙 a=$(($a + 2)) a=$(($a + 1)) a=$(($a+ 4)) echo "hehe!" elif [ $a -lt $b ] then echo $(($a + 100)) a=$(($a + 12)) echo "a is:"$a echo "hello world!" else echo "i dont know" fi
3.綜合實驗
#!/bin/bash #echo "start..." #define a function to read all the files in the folder #賦初始值 a10=0 a20=0 a30=0 a40=0 a50=0 a60=0 a70=0 #定義讀取文件名的函數(shù) function readfile () { for file in `ls $1` do if [ -d $1"/"$file ] then #這里采用遞歸的方法來讀取文件名 readfile $1"/"$file else #這一步使得temp變量獲得文件名 temp=`basename $file` #echo $temp #這里需要注意##*。。表示刪除字符串最右邊。。及其左邊所有內(nèi)容 var=${temp##*M} #%。。*表示刪除字符串左邊的。。及其右邊的內(nèi)容!兩個%%則表示最左邊 var1=${var%.*} var2=${var1%a*} var3=${var2%b*} var4=${var3%c*} var5=${var4%d*} var6=${var5%e*} var7=${var6%f*} var8=${var7%g*} #echo $var8 #if 和括號之間必須有空格 if [ $var8 -le 10 ] then a10=$(($a10 + 1)) elif [ $var8 -gt 10 -a $var8 -le 20 ] then a20=$(($a20 + 1)) elif [ $var8 -gt 20 -a $var8 -le 30 ] then a30=$(($a30 + 1)) elif [ $var8 -gt 30 -a $var8 -le 40 ] then a40=$(($a40 + 1)) elif [ $var8 -gt 40 -a $var8 -le 50 ] then a50=$(($a50 + 1)) elif [ $var8 -gt 50 -a $var8 -le 60 ] then a60=$(($a60 + 1)) else a70=$(($a70 + 1)) fi fi #echo $var8 done #echo $a40 } folder="/home/cc/Age/data/MORPH" readfile $folder #打印出每個數(shù)字段的個數(shù) echo $a10 echo $a20 echo $a30 echo $a40 echo $a50 echo $a60 echo $a70
這里將該腳本保存為1.sh,在執(zhí)行的時候如果用指令sh 1.sh則會報里面內(nèi)容或者語法出錯。筆者為此迷惑了很久,最終查找資料找到的解決辦法是:
a) 首先,使sh文件為可執(zhí)行文件,命令: chmod +x 1.sh;
b) 然后在終端直接執(zhí)行./1.sh就可以執(zhí)行。
以上這篇利用shell腳本遍歷文件夾內(nèi)所有的文件并作整理統(tǒng)計的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
虛擬機中使用linux系啟用文件共享之后的文件存在的位置方法
下面小編就為大家?guī)硪黄摂M機中使用linux系啟用文件共享之后的文件存在的位置方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02shell查找某字符串在某文件中出現(xiàn)行數(shù)的方法
這篇文章主要介紹了shell查找某字符串在某文件中出現(xiàn)行數(shù)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02用shell腳本實現(xiàn)自動切換內(nèi)網(wǎng)和外網(wǎng)實現(xiàn)高可用
因為公司的服務器這段時間內(nèi)網(wǎng)網(wǎng)卡老是出現(xiàn)問題,然后就導致了網(wǎng)站的各種問題,因為我們的數(shù)據(jù)庫鏈接,redis還有sphinx鏈接都是走的內(nèi)網(wǎng),,所以就寫了這個腳本,在線上也跑了一段時間了,,也沒出過什么問題2013-06-06linux?中sed命令實現(xiàn)刪除文件的任意列(操作代碼)
這篇文章主要介紹了linux中sed命令實現(xiàn)刪除文件的任意列,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06shell的條件測試,變量測試,表達式中的0和1,數(shù)值判斷,字符串判斷
本文主要介紹了shell的條件測試,變量測試,表達式中的0和1,數(shù)值判斷,字符串判斷,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-01-01