Chinaunix首页 | 论坛 | 博客
  • 博客访问: 343080
  • 博文数量: 115
  • 博客积分: 1019
  • 博客等级: 准尉
  • 技术积分: 1104
  • 用 户 组: 普通用户
  • 注册时间: 2011-02-22 15:02
个人简介

别想万里,要把一只脚放到另一脚的前边

文章分类

全部博文(115)

文章存档

2018年(1)

2015年(2)

2014年(31)

2013年(38)

2012年(43)

我的朋友

分类: LINUX

2013-12-30 21:32:01

一、概述

read命令接收标准输入(键盘)的输入,或者其他文件描述符的输入。得到输入后,read命令将数据放入一个标准变量中。


二、使用举例(这里仅列出一些常用的选项)

1.基本读取

#!/bin/bash  echo -n "Enter your name:" #参数-n的作用是不换行,echo默认是换行  read  name #从键盘输入  echo "hello $name, welcome to my program" exit 0 #退出shell程序。

其等效于以下:

read -p "Enter your name:" name #-p参数,允许在read命令行中直接指定一个提示

在上面read后面的变量只有name一个,也可以有多个,这时如果输入多个数据,则第一个数据给第一个变量,第二个数据给第二个变量。如果输入数据个数过多,则最后剩下的所有值都给最后一个变量,如果太少输入不会结束。

2.在read命令行中也可以不指定变量

如果不指定变量,那么read命令会将接收到的数据放置在环境变量REPLY中

read -p "Enter a number" echo $REPLY # 没有指定变量,那么默认变量就是 REPLY 

3.计时输入
使用read命令存在着潜在危险。脚本很可能会停下来一直等待用户的输入。如果无论是否输入数据脚本都必须继续执行,那么可以使用 -t 选项指定一个计时器,指定read命令等待输入的秒数。当计时满时,read命令返回非零值(0为正常退出状态); 

复制代码
#!/bin/bash  if read -t 5 -p "please enter your name:" name  # 限制5s 内完成变量赋值操作
then 
    echo "hello $name, welcome to my script" else echo "sorry,too slow" fi 
exit 0 
复制代码

3.设置计数输入的字符
当输入的字符数目达到预定数目时,自动退出,并将输入的数据赋值给变量。 

复制代码
#!/bin/bash  read -n1 -p "Do you want to continue [Y/N]? " answer  # -n1 限制输入的字符必须是一个, -s输入的东西不回显示
case $answer in Y|y) 
    echo "fine ,continue";; 
N|n) 
    echo "ok,good bye";; 
*) 
    echo "error choice";; 
esac
exit 0 
复制代码

该例子使用了-n选项,后接数值1,指示read命令只要接受到一个字符就退出。只要按下一个字符进行回答,read命令立即接受输入并将其传给变量。无需按回车键。 
4.默读(输入不显示在监视器上)

有时不希望输入的数据显示在监视器上。典型的例子就是输入密码,当然还有很多其他需要隐藏的数据。-s 选项能够使read命令中输入的数据不显示在监视器上(实际上,数据是显示的,只是read命令将文本颜色设置成与背景相同的颜色)。

#!/bin/bash  read  -s  -p "Enter your password: " pass 
echo "your password is $pass" exit 0 

5.读文件

每次调用read命令都会读取文件中的"一行"文本。当文件没有可读的行时,read命令将以非零状态退出。读取文件的关键是如何将文本中的数据传送给read命令。最常用的方法是对文件使用cat命令并通过管道将结果直接传送给包含read命令的while命令 。
 

复制代码
#!/bin/bash  count=1
cat dat| while read line #cat 命令的输出作为read命令的输入,read读到的值放在line中  do echo "$count:$line" count=$(($count + 1))
done
exit 0
复制代码
阅读(843) | 评论(0) | 转发(0) |
0

上一篇:bash 中数组操作

下一篇:sql 优化

给主人留下些什么吧!~~