作为程序员一定要保持良好的睡眠,才能好编程

Shell脚本从文件中逐行读取内容的几种方法实例

发布时间:2019-04-14

从文件逐行读取数据的方法有两种,

一种是在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