在linux下一般用while read line与for循环按行读取文件。现有如下test.txt文件:

5dc7781f04c3?utm_campaign=haruki

1. while read line

while read line; do

echo $line

done < test.txt

输出结果与上图一致。

这里也可以写为:

cat test.txt | while read line; do

echo $line

done

输出结果一致,但是需要注意一点,就是在如下情况下结果是不同的:

# 第一种情况

while read line; do

name1=$line;

done < test.txt

echo $name1

# 第二种情况:

cat test.txt | while read line; do

name2=$line

done

echo $name2

在第一种情况下输出:

ENSMUSG00000000078.7 32.83699 29.78868 38.58607 30.348110000000002

第二种情况则无输出。

出现这种不同,是因为管道的机制,这个使用管道之后while read line是在子shell中进行的,所以退出之后$name2就没有值了。并且,cat 会一次性地把test.txt的所有内容都输入到内存,假如文件很大,则会占用很大的内存。但是第二种重定向的方法,是一行一行的读入,更省内存。

2. for循环

for i in `cat test.txt`;do

echo $i

done

但是输出了这样的结果(部分结果):

5dc7781f04c3?utm_campaign=haruki

这是因为,在for循环中,每次是以空格/制表符为分割符输出。可以写成以下形式输出:

# 可以先将空格转为别的字符

for i in `sed 's/\t/#/g' test.txt`;do

echo $i | sed 's/#/\t/g'

done

先将空格或者制表符替换为其他字符,输出的时候再替换回来即可。

欢迎关注!

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐