從文件逐行讀取數據的方法有兩種,一種是在while循環或until循環中使用read命令,通過文件描述符一行一行的讀取文件內容;另一種是在for循環中使用cat filename>來讀取文件的內容。
1.使用for循環從文件中逐行讀取內容:在默認情況現下此方法是逐個單詞的讀取文件內容,因為使用這種方法讀取文件時,他使用環境變量IFS的值作為分隔符,由于IFS的默認值是“space/空格>”“tab/制表符>”“newline/新行>”,所以他首先以空格作為分隔符來讀取文件內容,因此如果使用for循環逐行讀取內容,在for循環開始之前需要先修改變量IFS的值,等for循環結束后再將IFS的值改回來。
示例1:
#!/bin/bash
bak=$IFS #定義一個變量bak保存IFS的值
if [ $# -ne 1 ];then #判斷位置參數是否為1
echo "Usage $0 filename"
exit
fi
if [ ! -f $1 ];then #判斷位置參數是否為文件
echo "the $1 is not a file"
exit
fi
IFS=$'\n' #將環境變量IFS的值修改為換行符
for i in `cat $1` #逐行讀取文件內容并打印到屏幕
do
echo $i
done
IFS=$bak #將環境變量IFS的值改回原值

示例2:如果不修改變量IFS的值,系統默認按照IFS的原值,按空格來讀取文件
#!/bin/bash
if [ $# -ne 1 ];then
echo "Usage $0 filename"
exit
fi
if [ ! -f $1 ];then
echo "the $1 is not a file"
exit
fi
for i in `cat $1`
do
echo $i
done

2.在腳本中定義代碼塊,使用重定向逐行讀取文件內容:
示例:
#!/bin/bash
if [ $# -ne 1 ];then #判斷腳本參數是否為1
echo "Usage:$0 filename"
exit 1
fi
file=$1 #將腳本參數參數賦值給變量file
{ #定義代碼塊,大括號{}中的代碼即為代碼塊
read line1
read line2
} $file #使用$file將代碼塊的標準輸入指向文件$file
echo "first line in $file is $line1" #輸出文件內容
echo "second line in $file is $line2"
exit 2

3.使用while循環結合read命令逐行讀取文件內容:
#!/bin/bash
if [ $# -ne 1 ];then
echo "Usage:$0 filename"
exit 1
fi
file=$1
if [ ! -f $file ];then
echo "the $file is not a file"
exit 2
fi
count=0
while read line #使用read命令循環讀取文件內容,并將讀取的文件內容賦值給變量line
do
let count++
echo "$count $line"
done $file #“done $file”將整個while循環的標準輸入指向文件$file
echo -e "\ntotle $count lines read"
exit 0



總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
您可能感興趣的文章:- 使用shell腳本每天對MySQL多個數據庫自動備份的講解
- shell腳本操作mysql數據庫刪除重復的數據
- shell腳本批量刪除es索引的方法
- Java調用shell腳本解決傳參和權限問題的方法
- springboot打包不同環境配置以及shell腳本部署的方法
- Shell中的while循環幾種使用實例詳解
- Linux Shell在目錄下使用for循環結合if查找文件的巧用
- Shell腳本判斷用戶的輸入內容
- Shell腳本中使用getopts處理多命令行選項
- shell腳本實現監控某個進程意外停止后拉起進程