婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 利用shell腳本遍歷文件夾內所有的文件并作整理統計的方法

利用shell腳本遍歷文件夾內所有的文件并作整理統計的方法

熱門標簽:宿松高德地圖標注 電銷機器人加盟多少錢 申請400電話有什么用 網絡電話外呼系統撥號軟件 汨羅代理外呼系統 4層電梯外呼控制系統設計 天津智能外呼系統排名 貴陽400電話到哪里去辦理 400電話申請找

環境: Ubuntu下采用shell腳本實現

案例簡述: 文件夾內有許多子文件夾,這里需要自動讀取所有的文件,包括他們的地址和文件名。通過觀察文件名的規律,按照一定的規則裁剪出文件名的某一部分,該部分為數字,則根據數字的大小統計該文件夾內文件在各個數據段的數量。

1.這里寫一個函數,實現對文件夾內所有文件名的讀取,采用的方法是遞歸!

#!/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
}
#函數定義結束,這里用來運行函數
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

#定義讀取文件名的函數
function readfile ()
{
 for file in `ls $1`
 do
 if [ -d $1"/"$file ]
 then
#這里采用遞歸的方法來讀取文件名
  readfile $1"/"$file
 else
#這一步使得temp變量獲得文件名
  temp=`basename $file`
#echo $temp
#這里需要注意##*。。表示刪除字符串最右邊。。及其左邊所有內容
var=${temp##*M}
#%。。*表示刪除字符串左邊的。。及其右邊的內容!兩個%%則表示最左邊
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 
#打印出每個數字段的個數
echo $a10
echo $a20
echo $a30
echo $a40
echo $a50
echo $a60
echo $a70 

這里將該腳本保存為1.sh,在執行的時候如果用指令sh 1.sh則會報里面內容或者語法出錯。筆者為此迷惑了很久,最終查找資料找到的解決辦法是:

a) 首先,使sh文件為可執行文件,命令: chmod +x 1.sh;

b) 然后在終端直接執行./1.sh就可以執行。

以上這篇利用shell腳本遍歷文件夾內所有的文件并作整理統計的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Shell腳本遍歷目錄并批量修改文件編碼
  • shell遞歸輸出文件名和目錄名的方法
  • shell獲取目錄下所有文件夾的名稱并輸出的實例
  • linux Shell獲取某目錄下所有文件夾的名稱
  • 詳解shell 遍歷文件夾內所有文件并打印絕對路徑
  • shell腳本遞歸遍歷目錄及子目錄的例子分享
  • shell 遞歸遍歷目錄下的所有文件并統一改名的方法

標簽:撫州 臨沂 烏蘭察布 昌都 廣東 連云港 贛州 海北

巨人網絡通訊聲明:本文標題《利用shell腳本遍歷文件夾內所有的文件并作整理統計的方法》,本文關鍵詞  利用,shell,腳本,遍歷,文件夾,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《利用shell腳本遍歷文件夾內所有的文件并作整理統計的方法》相關的同類信息!
  • 本頁收集關于利用shell腳本遍歷文件夾內所有的文件并作整理統計的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 怀仁县| 聊城市| 清新县| 新乐市| 云阳县| 合作市| 宁南县| 甘泉县| 政和县| 饶平县| 河北区| 剑河县| 九台市| 苏尼特左旗| 临澧县| 峨眉山市| 应用必备| 盐边县| 青河县| 靖边县| 剑川县| 仙桃市| 岳西县| 镇平县| 维西| 泸溪县| 平远县| 随州市| 徐闻县| 藁城市| 获嘉县| 阿克| 通化县| 云林县| 漳州市| 福建省| 福鼎市| 江城| 八宿县| 惠州市| 仲巴县|