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 linedo    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}"

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

原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/196209.html

(0)
上一篇 2021年11月16日
下一篇 2021年11月16日

相关推荐

发表回复

登录后才能评论