Shell 编程-文件读取方法集锦

Shell编程-文件读取方法集锦

分类: shell脚本学习 2779人阅读 评论(1) 收藏 举报
 

1 ,在这里总结一下Shell读取文件的方法

[plain] view plain copy print ?
  1. a),  
  2. #使用read命令读取一行数据  
  3. while read myline  
  4. do  
  5.     echo "LINE:"$myline  
  6. done < datafile.txt  
  7.   
  8. b),  
  9. #使用read命令读取一行数据  
  10. cat datafile.txt | while read myline  
  11. do   
  12.     echo "LINE:"$myline  
  13. Done  
  14.   
  15. c),  
  16. #读取一行数据  
  17. cat datafile.txt | while myline=$(line)  
  18. do   
  19.     echo "LINE:"$myline  
  20. Done  
  21.   
  22. d),  
  23. #读取一行数据  
  24. while myline=$(line)  
  25. do   
  26.     echo "LINE:"$myline  
  27. done < datafile.txt  
  28.   
  29. e),  
  30. #使用read命令读取变量数据  
  31. cat datafile.txt | while read paraa parab parac  
  32. do  
  33.     echo "PARAA:"$paraa  
  34.     echo "PARAB:"$parab  
  35.     echo "PARAC:"$parac  
  36. Done  
  37.   
  38. f),  
  39. #使用read命令读取变量数据  
  40. while read paraa parab parac  
  41. do  
  42.     echo "PARAA:"$paraa  
  43.     echo "PARAB:"$parab  
  44.     echo "PARAC:"$parac  
  45. done < datafile.txt  


 

G),

下面这个是在学习公司的代码时碰到的,其实不能算是读取文件,应该算是从标准输入读取,代码如下:

[plain] view plain copy print ?
  1. #!/bin/sh   
  2.   
  3. ip=192.168.253.111  
  4. while read line <&3 ; do  
  5.         echo "  attempt with ($line)"  
  6.         # Try to connect and exit when done if it worked.  
  7.         $line && exit 0  
  8. done 3<<EOF  
  9. /usr/bin/rlogin -l snap-admin $ip  
  10. /usr/bin/ssh dev@$ip  
  11. /usr/bin/ssh snap-admin@$ip  
  12. /usr/bin/ssh root@$ip  
  13. EOF  


 

网上有解释说下面这个格式:

<<EOF

(内容)

EOF

    把EOF替换成其他东西

意思是把内容当作标准输入传给程序

在这个例子中这么写 3<<EOF 应该是把它重定向到一个文件描述符中,大家都知道文件描述符都是一个整形,这里的3就是作为一个文件描述符来用。

这里再简要回顾一下< <的用法。当s h e l l看到< <的时候,它就会知道下一个词是一个分界符。在该分界符以后的内容都被当作输入,直到s h e l l又看到该分界符(位于单独的一行)。这个分界符可以是你所定义的任何字符串。

下面是对常见的文件描述符命令的整理:

[plain] view plain copy print ?
  1. command > filename  把标准输出重定向到一个新文件中  
  2.  command >> filename  把标准输出重定向到一个文件中(追加)  
  3.  command 1 > filename  把标准输出重定向到一个文件中  
  4.  command > filename 2 >&1 把标准输出和标准错误一起重定向到一个文件中  
  5.  command 2 >filename  把标准错误重定向到一个文件中  
  6.  command 2 >> filename  把标准错误重定向到一个文件中(追加)  
  7.  command >> filename 2 >&1 把标准输出和标准错误一起重定向到一个文件中(追加)  
  8.  command < filename > filename2 command命令以filename文件作为标准输入,  
  9.       以filename2文件作为标准输出  
  10.  command < filename  command命令以filename文件作为标准输入  
  11.  command << delimiter  从标准输出中读入,直至遇到delimiter分界符  
  12.  command <&m   把文件描述符m作为标准输出  
  13.  command >&m   把标准输出重定向到文件描述符m中  
  14.  command <&-   关闭标准输入  


 

2 ,就read命令的使用方法整理如下:

read命令从标准输入读取一行,并把输入行的每个字段(以指定的分隔符分隔)的值赋给命令行上的变量。 

[plain] view plain copy print ?
  1. read [-ers] [-u fd] [-t timeout] [-p prompt] [-a array] [-n nchars] [-d delim] [name ...]  


 

参数解析: 

-e

 

-r

指定读取命令把\(反斜杠)做为输入行的一个普通字符,而非控制字符。

-s

安静模式。如果指定该参数且从终端读入数据,那么输入的时候将不回显在屏幕上。

-u <fd>

指定读入数据的文件描述符,不再使用默认的标准输入。

-t <timeout>

等待标准输入的超时时间,单位为秒。如果在指定的时间内没有输入,即时返回。

-p <prompt>

打印提示符,等待输入,并将输入赋值给REPLY变量或者指定的变量。

-a <array>

读入一组词,依次赋值给数组array

-n <nchars>

读取指定的字符数。如果已读取n个字符,马上返回,下次从返回点继续读取;如果已到行结束,无论满不满足n个字符都返回。

-d <delim>

指定行结束符,读到该字符就当做一行的结束。

name ...

指定read变量。read读取一行数据后,分隔行数据为各个字段,然后将字段依次赋给指定的变量。如果分隔后的字段数目比指定的变量多,那么将把剩余的全部字段值都赋给最后的那个变量;反之,剩余的变量被赋值为空字符串。如果read没有指定变量,系统使用默认的REPLY作为缺省变量名。 

使用重定向读取数据 

[plain] view plain copy print ?
  1. exec 6< datafile.txt  
  2. while read -u 6 myline  
  3. do  
  4.     echo "LINE:"$myline  
  5. done  


 

变量分隔符 
read命令默认的分隔符是空格,多个空格被当做一个空格处理。我们也可以使用IFS(内部字段分隔符)指定的的字符作为分隔符。假如有如下内容的一个文件,它以$来分隔变量,希望把每个变量区别开来,可以使用如下脚本: 

baidu$google$tencnt$sina

123456789

[plain] view plain copy print ?
  1. #使用read命令读取变量数据  
  2. while read paraa parab parac parad  
  3. do  
  4.     echo "PARAA:"$paraa  
  5.     echo "PARAB:"$parab  
  6.     echo "PARAC:"$parac  
  7.     echo "PARAD:"$parad  
  8. done < datafile.txt  
  9. 执行脚本的输出如下:   
  10. PARAA:baidu  
  11. PARAB:google  
  12. PARAC:tencent  
  13. PARAD:sina  
  14. PARAA:123456789  
  15. PARAB:  
  16. PARAC: 

你可能感兴趣的:(shell脚本学习)