經(jīng)常會對文體文件進行逐行處理,在Shell里面如何獲取每行數(shù)據(jù),然后處理該行數(shù)據(jù),最后讀取下一行數(shù)據(jù),循環(huán)處理.有多種解決方法如下:
1.通過read命令完成.
read 命令從標準輸入中讀取一行,并把輸入行的每個字段的值指定給 shell 變量,用 IFS(內(nèi)部字段分隔符)變量中的字符作為分隔符。VariableName (變量名)參數(shù)指定給每一個字段的值,由 VariableName (變量名)參數(shù)指定的以此類推,直到最后一個字段。
read命令接收標準輸入,或其他文件描述符的輸入,得到輸入后,read命令將數(shù)據(jù)放入一個標準變量中.
利用read讀取文件時,每次調(diào)用read命令都會讀取文件中的"一行"文本.
當文件沒有可讀的行時,read命令將以非零狀態(tài)退出.
cat data.dat | while read line
do
echo "File:${line}"
done
while read line
do
echo "File:${line}"
done data.dat
2.使用awk命令完成
awk是一種優(yōu)良的文本處理工具,提供了極其強大的功能.
語法格式:awk [選項] '指令' 操作文件
常用選項:-F 指定分隔符,分隔符用""引起來
-v:var=value在awk程序開始之前指定一個值valu給變量var,這些變量值用于awk程序的BEGIN快
-f:后面跟一個保存了awk程序的文件,代替在命令行指定awk程序
利用awk讀取文件中的每行數(shù)據(jù),并且可以對每行數(shù)據(jù)做一些處理,還可以單獨處理每行數(shù)據(jù)里的每列數(shù)據(jù).
cat data.dat | awk '{print $0}'
cat data.dat | awk 'for(i=2;iNF;i++) {printf $i} printf "\n"}'
第1行代碼輸出data.dat里的每行數(shù)據(jù),第2代碼輸出每行中從第2列之后的數(shù)據(jù).
如果是單純的數(shù)據(jù)或文本文件的按行讀取和顯示的話,使用awk命令比較方便.
3.使用for var in file 命令完成
for var in file 表示變量var在file中循環(huán)取值.取值的分隔符由$IFS確定.
for line in $(cat data.dat)
do
echo "File:${line}"
done
for line in `cat data.dat`
do
echo "File:${line}"
done
如果輸入文本每行中沒有空格,則line在輸入文本中按換行符分隔符循環(huán)取值.
如果輸入文本中包括空格或制表符,則不是換行讀取,line在輸入文本中按空格分隔符或制表符或換行符特環(huán)取值.
可以通過把IFS設置為換行符來達到逐行讀取的功能.
IFS的默認值為:空白(包括:空格,制表符,換行符).
總結(jié)
到此這篇關(guān)于Shell腳本如何逐行處理文本文件的文章就介紹到這了,更多相關(guān)Shell處理文本文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Shell文本處理三劍客之sed的使用
- shell文件處理筆記之插入文本到文件的方法
- Shell腳本學習指南之文本處理工具
- 關(guān)于使用shell腳本循環(huán)處理文本的問題