从文件逐行读取数据的方法有两种,
一种是在while循环或until循环中使用read命令,通过文件描述符一行一行的读取文件内容;
另一种是在for循环中使用cat <filename>来读取文件的内容。
1、.使用for循环从文件中逐行读取内容:在默认情况现下此方法是逐个单词的读取文件内容,因为使用这种方法读取文件时,他使用环境变量IFS的值作为分隔符,由于IFS的默认值是“<space/空格>”“<tab/制表符>”“<newline/新行>”,所以他首先以空格作为分隔符来读取文件内容,因此如果使用for循环逐行读取内容,在for循环开始之前需要先修改变量IFS的值,等for循环结束后再将IFS的值改回来。
readfile.sh
#!/bin/bash bak=$IFS if [ ! -f $1 ];then echo "the $1 is not a file" exit fi #IFS='\n' //这里 设置IFS 替换的值 for str in `cat $1` do echo $str done
read.txt
abc bcd c d f song bbbaaaaaa CsonY ong zzz
./readfile.sh read.txt
这种使用\n 替换的方式也是有些问题的,如果内容中包含有 n 则会进行替换的。
执行结果:
abc bcd c d f so g bbbaaaaaa Cso Y o g zzz
把 song 中的n 进行了替换。 不管是否单双引号都会进行替换。
2、如果不修改IFS的值,将按照 空格进行分割,读取内容
#!/bin/bash bak=$IFS if [ ! -f $1 ];then echo "the $1 is not a file" exit fi for str in `cat $1` do echo $str done
read.txt
abc bcd zzz
./readfile.sh read.txt
3、使用while循环进行读取
#!/bin/bash if [ ! -f $1 ];then echo "the $1 is not a file" exit fi file=$1 while read line #使用read命令循环读取文件内容,并将读取的文件内容赋值给变量line do let count++ echo "$count $line" done <$file #“done <$file”将整个while循环的标准输入指向文件$file echo -e "\ntotle $count lines read" exit 0
这种方式是真正的读取一行的。不会因为 换行 或自定义的内容替换。
1 abc 2 bcd 3 c d f song 4 bbbaaaaaa 5 CsonY ong 6 zzz totle 6 lines read