Shell编程 | 脚本参数与交互及常见问题

在执行一个脚本程序时,会经常需要向脚本传递一些参数,并根据输入的参数值生成相应的数据或执行特定的逻辑。

向脚本传递参数

执行Shell脚本时可以带有参数,在Shell脚本中有变量与之对应进行引用。这类变量的名称很特别,分别是0、1、2、3...被称为位置变量。

 位置变量是由 0 开始,其中 0 变量预留用来保存实际脚本的名字,1 变量对应脚本程序的第 1个参数,依次类推。与其他变量一样,可以在Shell 中通过“$”符号来引用位置变量的值。

[root@localhost 20190105]# vi paral.sh 
#!/bin/bash
#显示脚本名
echo 'The script name is '$0
#显示第1个参数
echo 'The 1th parameter is '$1
#显示第2个参数
echo 'The 2th parameter is '$2
#显示第3个参数
echo 'The 3th parameter is '$3
#显示第4个参数
echo 'The 4th parameter is '$4
#显示第5个参数
echo 'The 5th parameter is '$5
#显示第6个参数
echo 'The 6th parameter is '$6
#显示第7个参数
echo 'The 7th parameter is '$7
#显示第8个参数
echo 'The 8th parameter is '$8
#显示第9个参数
echo 'The 9th parameter is '$9
[root@localhost 20190105]# ./paral.sh Ni hao , Nice to meet you !
The script name is ./paral.sh
The 1th parameter is Ni
The 2th parameter is hao
The 3th parameter is ,
The 4th parameter is Nice
The 5th parameter is to
The 6th parameter is meet
The 7th parameter is you
The 8th parameter is !
The 9th parameter is      //空值
[root@localhost 20190105]#

用户交互

使用 read 命令可以从键盘上读取数据,然后赋给指定的变量,在Shell脚本中实现与用户的数据交互。

 read命令的格式

read 变量1 [变量2...]

read命令可以从键盘上读取到多个变量的值,用户输入数据时,数据间以空格或者 Tab键作为分隔。

如果变量个数与输入的数据个数相同,则依次对应赋值;

如果变量个数大于输入的数据个数,则从左到右对应赋值;如果没有数据,则以之对应的变量为空;

如果变量个数少于输入的数据个数,则从左到右对应赋值,最后一个变量被赋予剩余的所有数据。

通过 read 命令读取键盘上输入的数据保存到变量中,同时把变量值显示在屏幕上,当用户输入 exit 时结束程序。

[root@localhost 20190105]# vi read1.sh 
#!/bin/bash
#初始化变量的值
input1=''                                               #设置 input1 变量值为空
input2=''                                               #设置 input2 变量值为空
input3=''                                               #设置 input3 变量值为空
input4=''                                               #设置 input4 变量值为空
#until 循环,当 input1 变量的值为 exit 时退出该循环
until [ "$input1" = exit ]
do
       echo 'Please input the values:'
#读取键盘输入的数据
       read input1 input2 input3 input4
#输入的不是 exit 时把用户输入的数据显示在屏幕上
       if [ "$input1" != exit ]
       then
               echo 'input1: '$input1                  #输出变量 input1 的值
               echo 'input2: '$input2                  #输出变量 input2 的值
               echo 'input3: '$input3                  #输出变量 input3 的值
               echo 'input4: '$input4                  #输出变量 input4 的值
               echo
#当输入为 exit 时显示退出脚本的提示
       else
               echo 'Exit the script.'
       fi
done
[root@localhost 20190105]# chmod +x read1.sh 
[root@localhost 20190105]# ./read1.sh 
Please input the values:
How do you do           //输入的数据个数与变量个数相等
input1: How
input2: do
input3: you
input4: do

Please input the values:
Welcome to beijing       //输入的数据个数小于变量个数
input1: Welcome
input2: to
input3: beijing
input4: 

Please input the values:
let's go              //输入的数据个数小于变量个数
input1: let's
input2: go
input3: 
input4: 

Please input the values:
Nice to meet you,too!      //输入的数据个数大于变量个数
input1: Nice
input2: to
input3: meet
input4: you,too!

Please input the values:    //结束程序
exit
Exit the script.
[root@localhost 20190105]#

运行结果可以看出:

  1. 当变量个数大于输入的数据个数时,没有数据与之对应的变量的值为空;
  2. 当变量个数小于输入的数据个数时,最后一个变量会被赋予剩余的所有数据;

特殊变量

特殊变量及说明
变量名说明
$#传递给脚本的参数个数
$*传递给脚本的所有参数的值
$@与$*相同
$$脚本执行所对应的进程号
$!后台运行的最后一个进程的进程号
$-显示Shell使用的当前选项
$?显示命令的退出状态,0:正确,1:错误。
[root@localhost 20190105]# vi vall.sh
#!/bin/bash
echo 'The value of $# is: '$#           //输出$#变量的值
echo 'The value of $* is: '$*           //输出$*变量的值
echo 'The value of $@ is: '$@           //输出$@变量的值
echo 'The value of $$ is: '$$           //输出$$变量的值
echo 'The value of $! is: '$!           //输出$!变量的值
echo 'The value of $- is: '$-           //输出$-变量的值
echo 'The value of $? is: '$?           //输出$?变量的值
[root@localhost 20190105]# ./vall.sh how do you do
The value of $# is: 4 //输出4变量的值
The value of $* is: how do you do //输出how do you do变量的值
The value of $@ is: how do you do //输出how do you do变量的值
The value of $$ is: 9040 //输出9040变量的值
The value of $! is:  //输出变量的值
The value of $- is: hB //输出hB变量的值
The value of $? is: 0 //输出0变量的值
[root@localhost 20190105]#

Shell编程常见问题

  • 如何屏蔽命令的输出结果

     Linux 默认会创建一个设备文件/dev/null(空设备),所有输出到该设备的信息都会被屏蔽。通过把命令的输出重定向到设备/dev/null,可以屏蔽命令的输出结果。

命令 > /dev/null

屏蔽命令的错误输出

命令 2> /dev/null

屏蔽命令的正常以及错误输出

命令 > /dev/null 2> /dev/null

例如:要在 Shell 代码中使用 grep 命令查找文件是否存在某个关键字,但是又希望屏幕 grep 命令的输出。

if grep jack /etc/passwd > /dev/null
then
 echo "jack found"
fi

如果 /etc/passwd 文件中有 jack 关键字的信息,将会显示 jack found,但不会输出 grep 命令的执行结果。

  • 如何把一条命令分成多行编写

Linux 的 Shell 脚本功能非常强大,它允许用户通过管道方式把多个命令组合在一起,但因此往往也导致在一行 Shell 脚本代码中编写的命令过长,难以阅读,为了使脚本的结构更加清晰,可以把一行 Shell 脚本代码分成多行进行编写。

使用两个管道符把ps、grep 和 awk 命令组合。

[root@localhost ~]# ps -ef | grep sshd | awk '{print $2}'
4478
12821
22028

在一行代码中把多个命令组合在一起,难以阅读。Shell 提供了一个特殊字符“\”,可以把一行代码分成多行进行编写。

[root@localhost ~]# ps -ef | \
> grep ssh | \
> awk '{print $2}'
4478
12821
23375
[root@localhost ~]#

 

转载于:https://www.cnblogs.com/jacktian-it/p/11550292.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux shell命令行及脚本编程是基于Linux操作系统的命令行环境下进行编程脚本开发的一种方式。通过这种方式,我们可以使用一系列预定义的命令和脚本语法来完成各种任务,例如自动化操作、批量处理等。 一个典型的Linux shell脚本编程实例是实现一个自动备份脚本。以下是该脚本的源码示例: ```bash #!/bin/bash # Automatic Backup Script # 定义备份目录和目标目录 backup_dir="/path/to/backup" target_dir="/path/to/target" # 创建备份目录 mkdir -p $backup_dir # 备份文件 backup_file="backup_$(date +%Y%m%d).tar.gz" # 根据当前日期生成备份文件名 tar -czf $backup_dir/$backup_file $target_dir # 将目标目录压缩成备份文件 # 检查备份是否成功并发送邮件通知 if [ $? -eq 0 ]; then # 如果备份成功 echo "Backup successful: $backup_file" # 在此处添加发送邮件的命令,例如使用sendmail或者mail等命令 else # 如果备份失败 echo "Backup failed" # 在此处添加发送邮件的命令,通知备份失败 fi ``` 该备份脚本首先定义了备份目录和目标目录的路径。然后,它创建了备份目录(如果不存在),接着使用`tar`命令将目标目录压缩成备份文件,文件名以当前日期为前缀。最后,根据备份命令的执行结果,判断备份是否成功并进行相应的邮件通知。 这只是一个简单的示例,实际上,Linux shell脚本编程可以涵盖更广泛的应用范围,包括系统管理、日志分析、自动化部署等。掌握了Linux shell命令行及脚本编程,我们可以更加高效地利用Linux操作系统进行各种任务处理和工作流程优化。 ### 回答2: Linux shell是一种命令行界面,用户可以直接在终端中输入命令来与操作系统进行交互。而shell脚本编程则是用脚本语言编写一系列的命令,以便自动化执行一些任务。 下面我们来介绍一个关于文件备份的实例。 假设我们有一个目录下的文件需要进行定期备份。我们可以编写一个shell脚本来完成这个任务。 首先,我们需要创建一个名为backup.sh的脚本文件。在文件中输入以下内容: ``` #!/bin/bash backup_dir="/path/to/backup/folder" source_dir="/path/to/source/folder" date=$(date +%Y%m%d) backup_file="backup_$date.tar.gz" tar -czvf "$backup_dir/$backup_file" "$source_dir" ``` 以上是一个简单的文件备份脚本。首先我们定义了备份目录和源目录的路径,然后使用`date`命令来获取当前日期,并将其作为备份文件的一部分命名。最后,我们使用`tar`命令将源目录打包成一个压缩文件,并将其保存在备份目录下。 要执行这个脚本,我们需要为脚本文件添加可执行权限。在终端中使用`chmod +x backup.sh`命令即可。 然后,我们可以在终端中执行脚本来进行备份操作。只需要输入`./backup.sh`即可开始备份过程。备份文件将保存在指定的备份目录下,并带有日期作为文件名的一部分。 通过编写这个简单的shell脚本,我们可以实现文件备份的自动化。可以根据实际需求进行修改和扩展,以适应不同的场景。这就是一个关于Linux shell命令行及脚本编程实例的详解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值