我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

shell按行读取文件的常见几种方法-创新互联

1.通过重定向+read命令

创新互联坚信:善待客户,将会成为终身客户。我们能坚持多年,是因为我们一直可值得信赖。我们从不忽悠初访客户,我们用心做好本职工作,不忘初心,方得始终。十载网站建设经验创新互联是成都老牌网站营销服务商,为您提供网站建设、做网站、网站设计、H5建站、网站制作、品牌网站设计小程序设计服务,给众多知名企业提供过好品质的建站服务。
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

方法三的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}"

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


本文题目:shell按行读取文件的常见几种方法-创新互联
文章地址:http://mswzjz.cn/article/djgihh.html

其他资讯