Linux read语法及浅析
read命令 -n(不换行) -p(提示语句) -n(字符个数) -t(等待时间) -s(不回显)
1、基本读取
read命令接收标准输入(键盘)的输入,或其他文件描述符的输入(后面在说)。得到输入后,read命令将数据放入一个标准变量中。下面是read命令
的最简单形式::
#!/bin/bash
echo -n "Enter your name:" //参数-n的作用是不换行,echo默认是换行
read name //从键盘输入
echo "hello $name,welcome to my program" //显示信息
exit 0 //退出shell程序。
//********************************
由于read命令提供了-p参数,允许在read命令行中直接指定一个提示。
所以上面的脚本可以简写成下面的脚本::
#!/bin/bash
read -p "Enter your name:" name
echo "hello $name, welcome to my program"
exit 0
在上面read后面的变量只有name一个,也可以有多个,这时如果输入多个数据,则第一个数据给第一个变量,第二个数据给第二个变量,如果输入数据个数过多,则最后所有的值都给第一个变量。如果太少输入不会结束。
//*****************************************
在read命令行中也可以不指定变量.如果不指定变量,那么read命令会将接收到的数据放置在环境变量REPLY中。
例如::
read -p "Enter a number"
环境变量REPLY中包含输入的所有数据,可以像使用其他变量一样在shell脚本中使用环境变量REPLY.
2、计时输入.
使用read命令存在着潜在危险。脚本很可能会停下来一直等待用户的输入。如果无论是否输入数据脚本都必须继续执行,那么可以使用-t选项指定一个计时器。
-t选项指定read命令等待输入的秒数。当计时满时,read命令返回一个非零退出状态;
#!/bin/bash
if read -t 5 -p "please enter your name:" name
then
echo "hello $name ,welcome to my script"
else
echo "sorry,too slow"
fi
exit 0
除了输入时间计时,还可以设置read命令计数输入的字符。当输入的字符数目达到预定数目时,自动退出,并将输入的数据赋值给变量。
#!/bin/bash
read -n1 -p "Do you want to continue [Y/N]?" answer
case $answer in
Y | y)
echo "fine ,continue";;
N | n)
echo "ok,good bye";;
*)
echo "error choice";;
esac
exit 0
该例子使用了-n选项,后接数值1,指示read命令只要接受到一个字符就退出。只要按下一个字符进行回答,read命令立即
接受输入并将其传给变量。无需按回车键。
3、默读(输入不显示在监视器上)
有时会需要脚本用户输入,但不希望输入的数据显示在监视器上。典型的例子就是输入密码,当然还有很多其他需要隐藏的数据。
-s选项能够使read命令中输入的数据不显示在监视器上(实际上,数据是显示的,只是read命令将文本颜色设置成与背景相同的颜色)。
#!/bin/bash
read -s -p "Enter your password:" pass
echo "your password is $pass"
exit 0
4、读文件
最后,还可以使用read命令读取Linux系统上的文件。
每次调用read命令都会读取文件中的"一行"文本。当文件没有可读的行时,read命令将以非零状态退出。
读取文件的关键是如何将文本中的数据传送给read命令。
最常用的方法是对文件使用cat命令并通过管道将结果直接传送给包含read命令的while命令
例子::
#!/bin/bash
count=1 //赋值语句,不加空格
cat test | while read line //cat 命令的输出作为read命令的输入,read读到的值放在line中
总结一下Shell读取文件的方法
a), #使用read命令读取一行数据 while read myline do echo "LINE:"$myline done < datafile.txt b), #使用read命令读取一行数据 cat datafile.txt | while read myline do echo "LINE:"$myline Done c), #读取一行数据 cat datafile.txt | while myline=$(line) do echo "LINE:"$myline Done d), #读取一行数据 while myline=$(line) do echo "LINE:"$myline done < datafile.txt e), #使用read命令读取变量数据 cat datafile.txt | while read paraa parab parac do echo "PARAA:"$paraa echo "PARAB:"$parab echo "PARAC:"$parac Done f), #使用read命令读取变量数据 while read paraa parab parac do echo "PARAA:"$paraa echo "PARAB:"$parab echo "PARAC:"$parac done < datafile.txt
下面这个其实不能算是读取文件,应该算是从标准输入读取,代码如下:
#!/bin/sh ip=192.168.253.111 while read line <&3 ; do echo " attempt with ($line)" # Try to connect and exit when done if it worked. $line && exit 0 done 3<<EOF /usr/bin/rlogin -l snap-admin $ip /usr/bin/ssh dev@$ip /usr/bin/ssh snap-admin@$ip /usr/bin/ssh root@$ip EOF
下面这个格式:
<<EOF
(内容)
EOF
把EOF替换成其他东西
意思是把内容当作标准输入传给程序
在这个例子中这么写 3<<EOF 应该是把它重定向到一个文件描述符中,大家都知道文件描述符都是一个整形,这里的3就是作为一个文件描述符来用。
这里再简要回顾一下<<的用法。
当shell看到<<的时候,它就会知道下一个词是一个分界符。
在该分界符以后的内容都被当作输入,直到shell又看到该分界符(位于单独的一行)。
这个分界符可以是你所定义的任何字符串。
下面是对常见的文件描述符命令的整理:
command > filename 把标准输出重定向到一个新文件中 command >> filename 把标准输出重定向到一个文件中(追加) command 1 > filename 把标准输出重定向到一个文件中 command > filename 2 >&1 把标准输出和标准错误一起重定向到一个文件中 command 2 >filename 把标准错误重定向到一个文件中 command 2 >> filename 把标准错误重定向到一个文件中(追加) command >> filename 2 >&1 把标准输出和标准错误一起重定向到一个文件中(追加) command < filename > filename2 command命令以filename文件作为标准输入, 以filename2文件作为标准输出 command < filename command命令以filename文件作为标准输入 command << delimiter 从标准输出中读入,直至遇到delimiter分界符 command <&m 把文件描述符m作为标准输出 command >&m 把标准输出重定向到文件描述符m中 command <&- 关闭标准输入
2 ,就read命令的使用方法整理如下:
read命令从标准输入读取一行,并把输入行的每个字段(以指定的分隔符分隔)的值赋给命令行上的变量。
read [-ers] [-u fd] [-t timeout] [-p prompt] [-a array] [-n nchars] [-d delim] [name ...]
参数解析:
-r
指定读取命令把“\”(反斜杠)做为输入行的一个普通字符,而非控制字符。
-s
安静模式。如果指定该参数且从终端读入数据,那么输入的时候将不回显在屏幕上。
-u <fd>
指定读入数据的文件描述符,不再使用默认的标准输入。
-t <timeout>
等待标准输入的超时时间,单位为秒。如果在指定的时间内没有输入,即时返回。
-p <prompt>
打印提示符,等待输入,并将输入赋值给REPLY变量或者指定的变量。
-a <array>
读入一组词,依次赋值给数组array。
-n <nchars>
读取指定的字符数。如果已读取n个字符,马上返回,下次从返回点继续读取;如果已到行结束,无论满不满足n个字符都返回。
-d <delim>
指定行结束符,读到该字符就当做一行的结束。
name ...
指定read变量。read读取一行数据后,分隔行数据为各个字段,然后将字段依次赋给指定的变量。如果分隔后的字段数目比指定的变量多,那么将把剩余的全部字段值都赋给最后的那个变量;反之,剩余的变量被赋值为空字符串。如果read没有指定变量,系统使用默认的REPLY作为缺省变量名。
使用重定向读取数据
exec 6< datafile.txt while read -u 6 myline do echo "LINE:"$myline done
变量分隔符
read命令默认的分隔符是空格,多个空格被当做一个空格处理。我们也可以使用IFS(内部字段分隔符)指定的的字符作为分隔符。假如有如下内容的一个文件,它以“$”来分隔变量,希望把每个变量区别开来,可以使用如下脚本:
baidu$google$tencnt$sina
123456789
#使用read命令读取变量数据 while read paraa parab parac parad do echo "PARAA:"$paraa echo "PARAB:"$parab echo "PARAC:"$parac echo "PARAD:"$parad done < datafile.txt 执行脚本的输出如下: PARAA:baidu PARAB:google PARAC:tencent PARAD:sina PARAA:123456789 PARAB: PARAC:
http://blog.csdn.net/xj178926426/article/details/6925770
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。