shell按行读取文件的常见几种方法



1.通过重定向+read命令

while read line
do
    #对每一行字符串的操作
    shell_commands
done < File.txt


2.通过cat +IFS重定义

IFS_old=$IFS
IFS=$'\n'
for line in $(cat File.txt)
do
    shell_commands
done
IFS=$IFS_old


3.管道+read命令(经常看到,但不好用的做法。)

cat File.txt | read line
do
    shell_commands
done


注意:这个方法有一个非常明显的缺陷。shell_command所定义的变量在循环结束后会"失效"!!


举例:

file1.txt 的内容如下:

a
b
c
d


方法一的shell代码:

   
#行数
line_count=0
#文件内容
file_content=""
#开始读取
while read line
do
    echo "我读取到了:"
    echo ${line}
    line_count=$(expr $line_count + 1)
    echo "这是第${line_count}行"
    file_content="$file_content $line"
done<file1.txt
#检验结果
echo "刚才的程序读取到文件file1.txt
有 ${line_count}行,
里面的内容为${file_content}"


方法三的shell代码

#行数
line_count=0
#文件内容
file_content=""
#开始读取
cat file1.txt | read line
do
    echo "我读取到了:"
    echo ${line}
    line_count=$(expr $line_count + 1)
    echo "这是第${line_count}行"
    file_content="$file_content $line"
done
#检验结果
echo "刚才的程序读取到文件file1.txt
有 ${line_count}行,
里面的内容为${file_content}"


大家验证一下两种方法的运行结果,就可以知道区别了。