shell脚本常用函数和命令(5)read 详解
1)命令格式
read [ -p ][ -r ][ -s ][ -u[ n ] ] [ VariableName ]
read 命令从标准输入中读取一行,并把输入行的每个字段的值指定给 shell 变量,用 IFS(内部字段分隔符)变量中的字符作为分隔符。
VariableName 参数指定 shell 变量的名称,shell 变量获取输入行一个字段的值。由VariableName 参数指定的第一个 shell 变量指定给每一个字段的值,
由VariableName参数指定的第二个shell变量指定给第二个字段的值,以此类推,直到最后一个字段。如果标准输入行的字段比相应的由 VariableName 参数指定的 shell 变量的个数多,
把全部余下的字段的值赋给指定的最后的 shell 变量。如果比 shell 变量的个数少,则剩余的 shell 变量被设置为空字符串。
注意: 如果省略了 VariableName 参数,变量 REPLY 用作缺省变量名。
-a 后跟一个变量,该变量会被认为是个数组,然后给其赋值,默认是以空格为分割符。(默认以换行符介绍,以空格分隔)
-d 后面跟一个标志符,其实只有其后的第一个字符有用,作为结束的标志,会举例说明。(即自己指定结束符,为跟在-d后的第一个字符,比如如果指定为eof,则结束字符就是e,则此时换行不会结束,只有在输入e时才会结束。)
-p 后面跟提示信息,即在输入前打印提示信息。
-e 在输入的时候可以时候命令补全功能。
-n 后跟一个数字,定义输入文本的长度,很实用。
-r 屏蔽\,如果没有该选项,则\作为一个转义字符,有的话 \就是个正常的字符了。
-s 安静模式,在输入字符时不再屏幕上显示,例如login时输入密码。
-t 后面跟秒数,定义输入字符的等待时间。
-u 后面跟fd,从文件描述符中读入,该文件描述符可以是exec新开启的。
1)基本读取-p
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命令行中直接指定一个提示。
[root@controller1 ~]# read -p "Enter your name:" name
Enter your name:xiao ming
[root@controller1 ~]# echo $name
xiao ming
在上面read后面的变量只有name一个,也可以有多个,这时如果输入多个数据,则第一个数据给第一个变量,第二个数据给第二个变量,如果输入数据个数过多,则最后所有的值都给第一个变量。如果太少输入不会结束。
在read命令行中也可以不指定变量.如果不指定变量,那么read命令会将接收到的数据放置在环境变量REPLY中。
[root@controller1 ~]# read -p "input num:"
input num:11 22 33
[root@controller1 ~]# echo $REPLY
11 22 33
环境变量REPLY中包含输入的所有数据,可以像使用其他变量一样在shell脚本中使用环境变量REPLY.
2)数组读取 -a
[root@controller1 ~]# read -a item
aa bb cc dd
[root@controller1 ~]# echo ${item[3]}
dd
[root@controller1 ~]# echo ${item[0]}
aa
利用数组读入多个参数,用数组下标取得参数
3)计时输入 -t 5:
使用read命令存在着潜在危险。脚本很可能会停下来一直等待用户的输入。如果无论是否输入数据脚本都必须继续执行,那么可以使用-t选项指定一个计时器。
-t选项指定read命令等待输入的秒数。当计时满时,read命令返回一个非零退出状态;
#!/bin/bash
if read -t 5 -p "please enter your name:" name
then
echo -e "hello ${name} ,welcome to linux world!\n"
else
echo -e "sorry,too slow\n"
fi
exit 0
3)计数输入 -n 1:
除了输入时间计时,还可以设置read命令计数输入的字符。当输入的字符数目达到预定数目时,自动退出,并将输入的数据赋值给变量。
#!/bin/bash
read –n 1 -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命令立即接受输入并将其传给变量。无需按回车键。
如果该脚本不能执行,用dos2unix转换一下格式
4)默读 -s :(输入不显示在监视器上)
有时会需要脚本用户输入,但不希望输入的数据显示在监视器上。典型的例子就是输入密码,当然还有很多其他需要隐藏的数据。
-s选项能够使read命令中输入的数据不显示在监视器上(实际上,数据是显示的,只是 read命令将文本颜色设置成与背景相同的颜色)。
[root@controller1 ~]# read -s -p "enter passwd:"pass
enter passwd:
5)读文件
最后,还可以使用read命令读取Linux系统上的文件。
每次调用read命令都会读取文件中的"一行"文本。当文件没有可读的行时,read命令将以非零状态退出。
读取文件的关键是如何将文本中的数据传送给read命令。
最常用的方法是对文件使用cat命令并通过管道将结果直接传送给包含read命令的 while命令
[root@controller1 ~]# cat >myread.sh<<eof
#!/bin/bash
count=1 #//赋值语句,不加空格
cat /root/demo-openrc | while read line #//cat 命令的输出作为read命令的输入,read读到的值放在line中
do #demo-openrc为要读的文件
echo "Line $count:$line"
count=$[ $count + 1 ] #//注意中括号中的空格。
done
echo "======read file finish====="
exit 0
eof
[root@controller1 ~]# sh myread.sh
Line 1:export OS_PROJECT_DOMAIN_NAME=Default
Line 2:export OS_USER_DOMAIN_NAME=Default
Line 3:export OS_PROJECT_NAME=demo
Line 4:export OS_USERNAME=demo
Line 5:export OS_PASSWORD=123456
Line 6:export OS_AUTH_URL=http://172.16.100.70:5000/v3
Line 7:export OS_IDENTITY_API_VERSION=3
Line 8:export OS_IMAGE_API_VERSION=2
1)命令格式
read [ -p ][ -r ][ -s ][ -u[ n ] ] [ VariableName ]
read 命令从标准输入中读取一行,并把输入行的每个字段的值指定给 shell 变量,用 IFS(内部字段分隔符)变量中的字符作为分隔符。
VariableName 参数指定 shell 变量的名称,shell 变量获取输入行一个字段的值。由VariableName 参数指定的第一个 shell 变量指定给每一个字段的值,
由VariableName参数指定的第二个shell变量指定给第二个字段的值,以此类推,直到最后一个字段。如果标准输入行的字段比相应的由 VariableName 参数指定的 shell 变量的个数多,
把全部余下的字段的值赋给指定的最后的 shell 变量。如果比 shell 变量的个数少,则剩余的 shell 变量被设置为空字符串。
注意: 如果省略了 VariableName 参数,变量 REPLY 用作缺省变量名。
-a 后跟一个变量,该变量会被认为是个数组,然后给其赋值,默认是以空格为分割符。(默认以换行符介绍,以空格分隔)
-d 后面跟一个标志符,其实只有其后的第一个字符有用,作为结束的标志,会举例说明。(即自己指定结束符,为跟在-d后的第一个字符,比如如果指定为eof,则结束字符就是e,则此时换行不会结束,只有在输入e时才会结束。)
-p 后面跟提示信息,即在输入前打印提示信息。
-e 在输入的时候可以时候命令补全功能。
-n 后跟一个数字,定义输入文本的长度,很实用。
-r 屏蔽\,如果没有该选项,则\作为一个转义字符,有的话 \就是个正常的字符了。
-s 安静模式,在输入字符时不再屏幕上显示,例如login时输入密码。
-t 后面跟秒数,定义输入字符的等待时间。
-u 后面跟fd,从文件描述符中读入,该文件描述符可以是exec新开启的。
1)基本读取-p
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命令行中直接指定一个提示。
[root@controller1 ~]# read -p "Enter your name:" name
Enter your name:xiao ming
[root@controller1 ~]# echo $name
xiao ming
在上面read后面的变量只有name一个,也可以有多个,这时如果输入多个数据,则第一个数据给第一个变量,第二个数据给第二个变量,如果输入数据个数过多,则最后所有的值都给第一个变量。如果太少输入不会结束。
在read命令行中也可以不指定变量.如果不指定变量,那么read命令会将接收到的数据放置在环境变量REPLY中。
[root@controller1 ~]# read -p "input num:"
input num:11 22 33
[root@controller1 ~]# echo $REPLY
11 22 33
环境变量REPLY中包含输入的所有数据,可以像使用其他变量一样在shell脚本中使用环境变量REPLY.
2)数组读取 -a
[root@controller1 ~]# read -a item
aa bb cc dd
[root@controller1 ~]# echo ${item[3]}
dd
[root@controller1 ~]# echo ${item[0]}
aa
利用数组读入多个参数,用数组下标取得参数
3)计时输入 -t 5:
使用read命令存在着潜在危险。脚本很可能会停下来一直等待用户的输入。如果无论是否输入数据脚本都必须继续执行,那么可以使用-t选项指定一个计时器。
-t选项指定read命令等待输入的秒数。当计时满时,read命令返回一个非零退出状态;
#!/bin/bash
if read -t 5 -p "please enter your name:" name
then
echo -e "hello ${name} ,welcome to linux world!\n"
else
echo -e "sorry,too slow\n"
fi
exit 0
3)计数输入 -n 1:
除了输入时间计时,还可以设置read命令计数输入的字符。当输入的字符数目达到预定数目时,自动退出,并将输入的数据赋值给变量。
#!/bin/bash
read –n 1 -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命令立即接受输入并将其传给变量。无需按回车键。
如果该脚本不能执行,用dos2unix转换一下格式
4)默读 -s :(输入不显示在监视器上)
有时会需要脚本用户输入,但不希望输入的数据显示在监视器上。典型的例子就是输入密码,当然还有很多其他需要隐藏的数据。
-s选项能够使read命令中输入的数据不显示在监视器上(实际上,数据是显示的,只是 read命令将文本颜色设置成与背景相同的颜色)。
[root@controller1 ~]# read -s -p "enter passwd:"pass
enter passwd:
5)读文件
最后,还可以使用read命令读取Linux系统上的文件。
每次调用read命令都会读取文件中的"一行"文本。当文件没有可读的行时,read命令将以非零状态退出。
读取文件的关键是如何将文本中的数据传送给read命令。
最常用的方法是对文件使用cat命令并通过管道将结果直接传送给包含read命令的 while命令
[root@controller1 ~]# cat >myread.sh<<eof
#!/bin/bash
count=1 #//赋值语句,不加空格
cat /root/demo-openrc | while read line #//cat 命令的输出作为read命令的输入,read读到的值放在line中
do #demo-openrc为要读的文件
echo "Line $count:$line"
count=$[ $count + 1 ] #//注意中括号中的空格。
done
echo "======read file finish====="
exit 0
eof
[root@controller1 ~]# sh myread.sh
Line 1:export OS_PROJECT_DOMAIN_NAME=Default
Line 2:export OS_USER_DOMAIN_NAME=Default
Line 3:export OS_PROJECT_NAME=demo
Line 4:export OS_USERNAME=demo
Line 5:export OS_PASSWORD=123456
Line 6:export OS_AUTH_URL=http://172.16.100.70:5000/v3
Line 7:export OS_IDENTITY_API_VERSION=3
Line 8:export OS_IMAGE_API_VERSION=2
======read file finish=====