从文件逐行读取数据的方法有两种,一种是在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”将整个wlbemTTUFWKhile循环的标准输入指向文件$file
echo -e "\ntotle $count lines read"
exit 0
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接