【Shell腳本】逐行處理文本文件


經常會對文體文件進行逐行處理,在Shell里面如何獲取每行數據,然后處理該行數據,最后讀取下一行數據,循環處理.有多種解決方法如下:

1.通過read命令完成.

read命令接收標准輸入,或其他文件描述符的輸入,得到輸入后,read命令將數據放入一個標准變量中.

利用read讀取文件時,每次調用read命令都會讀取文件中的"一行"文本.

當文件沒有可讀的行時,read命令將以非零狀態退出.

1 cat data.dat | while read line
2 do
3     echo "File:${line}"
4 done
5 
6 while read line
7 do 
8     echo "File:${line}"
9 done < data.dat

2.使用awk命令完成

awk是一種優良的文本處理工具,提供了極其強大的功能.

利用awk讀取文件中的每行數據,並且可以對每行數據做一些處理,還可以單獨處理每行數據里的每列數據.

1 cat data.dat | awk '{print $0}'
2 cat data.dat | awk 'for(i=2;i<NF;i++) {printf $i} printf "\n"}'

第1行代碼輸出data.dat里的每行數據,第2代碼輸出每行中從第2列之后的數據.

如果是單純的數據或文本文件的按行讀取和顯示的話,使用awk命令比較方便.

3.使用for var in file 命令完成

for var in file 表示變量var在file中循環取值.取值的分隔符由$IFS確定.

1 for line in $(cat data.dat)
2 do 
3     echo "File:${line}"
4 done
5 
6 for line in `cat data.dat`
7 do 
8     echo "File:${line}"
9 done

如果輸入文本每行中沒有空格,則line在輸入文本中按換行符分隔符循環取值.

如果輸入文本中包括空格或制表符,則不是換行讀取,line在輸入文本中按空格分隔符或制表符或換行符特環取值.

可以通過把IFS設置為換行符來達到逐行讀取的功能.

IFS的默認值為:空白(包括:空格,制表符,換行符).

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM