新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1.通过重定向+read命令
成都创新互联公司是专业的昆山网站建设公司,昆山接单;提供成都网站设计、成都网站建设、外贸网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行昆山网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
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://wjwzjz.com/article/pdohph.html