(一)首先来看shell脚本的执行方式,shell脚本的后缀名都是sh文件。
1 sh test.sh
2 source test.sh
这两种方式有什么区别呢。test.sh 里的脚本很简单, 从键盘输入名字后赋值个name变量
read -p “Please input your name:” name
执行如下
root@zhf-linux:/home/zhf/zhf/shell_prj# sh test1.sh
please input your name:zhf
root@zhf-linux:/home/zhf/zhf/shell_prj# echo $name
echo
$name是空值。原因前面介绍过。bash在执行脚本的时候,是另起一个子进程。当子进程完成后,子进程内的变量不会传入父进程中去
但是用source执行脚本就不一样了。
原因在于source对script的执行方式是在父进程中进行的。
root@zhf-linux:/home/zhf/zhf/shell_prj#
source test1.sh
please
input your name:zhf
root@zhf-linux:/home/zhf/zhf/shell_prj#
echo $name
zhf
在脚本中,避免不了要进行各种条件判断。条件判断有test
和[]两种方式
test方式:
read
-p "please input your name:" name
test
-z $name && echo "you must input your name"
-z
是判断字符串是否为0也就空字符串,如果是,则提示输入名字
root@zhf-linux:/home/zhf/zhf/shell_prj#
sh test1.sh
please
input your name:
you
must input your name
test有很多判断参数,具体可以用man
test的进行查看
[]方式:
read
-p "please input your name:" name
[
-z "$name" ] && echo "please input your name"
使用[]有几点需要注意:
1
在中括号内的每个组件都需要有空格键来分隔
2
在中括号内的变量都需要用双引号起来
关于第二点,如果不用双引号括起来,会引起如下问题:
root@zhf-linux:/home/zhf/zhf/shell_prj#
name="cq zhf"
root@zhf-linux:/home/zhf/zhf/shell_prj#
[ $name == "cq zhf" ]
bash:
[: too many arguments
原因在于$name=cq
zhf, 如果没有双括号,那么上面的不等式就等于
cq
zhf == “cq zhf”。系统会认为是2个变量,因此提示too
many arguments.
(二)script的变量。
在执行脚本的时候,会传入某些参数。那么在脚本里面如何监控这些参数呢
$#代表参数的个数
$@得到全部的参数
$1,$2…..代表的是各个参数。其中$0是指的脚本名称。
root@zhf-linux:/home/zhf/zhf/shell_prj#
sh test1.sh one two three
The
scritp name is test1.sh
The
total number of parameter is 3
The
first parameter is one
如果输入的变量太多,单从顺序上去记忆也比较麻烦,有一种参数偏移的方法可以省事一些。shift命令。这个命令的作用好比是一个FIFO的栈。
root@zhf-linux:/home/zhf/zhf/shell_prj#
sh test1.sh one two three
The
scritp name is test1.sh
The
total number of parameter is 3
The
first parameter is one
The
first parameter is two
其他流程控制语句,例如if,
when, for...do...done等都和其他语言用法类似。