1、显示脚本参数
我们可以在执行 Shell 脚本时,向脚本传递参数,脚本内获取参数的格式为:$n。n 代表一个数字,1 为执行脚本的第一个参数,2 为执行脚本的第二个参数,以此类推……(本质上属于变量替换)
- 实例:
#!/bin/bash
echo "向shell脚本传递参数!";
echo "执行的文件名:$0";
echo "第一个参数为:$1";
echo "第二个参数为:$2";
为脚本设置可执行权限,并执行脚本,输出结果如下所示:
$ chmod +x test.sh
$ ./test.sh 1 2
向shell脚本传递参数!
执行的文件名:./test.sh
第一个参数为:1
第二个参数为:2
常用参数
参数 | 说明 |
---|---|
$# | 传递给shell脚本的参数个数 |
$* | 以一个单字符串显示所有向shell脚本传递的参数。比如在双引号中的 $* 会以"$1 $2 … $n"的形式输出所有参数。 |
$@ | 与$*相同,但是在引号中返回每个参数。比如在双引号中的 $@ 会以"$1" "$2" … "$n" 的形式输出所有参数。 |
$$ | 脚本运行的当前进程ID号 |
$? | 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。 |
$* 与 $@ 区别:
- 相同点:都是引用所有参数。
- 不同点:只有在双引号中体现出来。假设在脚本运行时写了三个参数 1、2、3,,则 " * " 等价于 "1 2 3"(传递了一个参数),而 "@" 等价于 "1" "2" "3"(传递了三个参数)。
#!/bin/bash
echo "-- \$* 演示 ---"
for i in "$*"; do
echo $i
done
echo "-- \$@ 演示 ---"
for i in "$@"; do
echo $i
done
执行脚本,输出结果如下所示:
$ chmod +x test.sh
$ ./test.sh 1 2 3
-- $* 演示 ---
1 2 3
-- $@ 演示 ---
1
2
3
2、:获取 变量 与 环境变量 的值
在linux及unix的shell中,以 $ 开头的字符串表示的是shell中定义的变量,这些变量可以是系统自动增加的,也可以是用户自己定义的。
$PATH 表示的是系统的命令搜索路径,和windows的%path%是一样的, $HOME则表示是用户的主目录,也就是用户登录后工作目录
3、${}变量替换
${}用于变量替换。一般情况下,$var 与${var} 并没有啥不一样。但是用 ${} 会比较精确的界定变量名称的范围。比如原本是打算先将 $A 的结果替换出来,然后再补一个 B 字母于其后,但在命令行上,真正的结果却是只会提换变量名称为 AB 的值,若使用 ${ } 就没问题了:
[root@localhost ~]# A=B
[root@localhost ~]# echo $AB
[root@localhost ~]# echo ${A}B
BB
[root@localhost ~]#
${}功能扩展之获取路径、文件名、后缀
实例:
先赋值一个变量为一个路径,如下:
file=/dir1/dir2/dir3/my.file.txt
[root@localhost ~]# file=/dir1/dir2/dir3/my.file.txt
[root@localhost ~]# echo ${file}
/dir1/dir2/dir3/my.file.txt
[root@localhost ~]#
命令 | 命令解释 | 输出结果 |
---|---|---|
$ | 去掉第一个 / 及其前面(左侧)的字符串 | dir1/dir2/dir3/my.file.txt |
$ | 去掉最后一个 / 及其前面(左侧)的字符串 | my.file.txt |
$ | 去掉第一个 . 及其前面(左侧)的字符串 | file.txt |
$ | 去掉最后一个 . 及其前面(左侧)的字符串 | txt |
$ | 去掉最后一个 / 及其后面(右侧)的字符串 | /dir1/dir2/dir3 |
${file%%/* | 去掉第一个 / 及其后面(右侧)的字符串 | |
${file%.* | 去掉最后一个 . 及其后面(右侧)的字符串 | /dir1/dir2/dir3/my.file |
${file%%.* | 去掉第一个 . 及其后面(右侧)的字符串 | /dir1/dir2/dir3/my |
记忆方法如下:
- “#”是去掉左边(在键盘上 # 在 $ 之左边)
- “%”是去掉右边(在键盘上 % 在 $ 之右边)
- “*”是用来匹配不要的字符,也就是想要去掉的那部分
${}功能扩展之取子串和替换
[root@localhost ~]# echo ${file}
/dir1/dir2/dir3/my.file.txt
命令 | 命令解释 | 输出结果 |
---|---|---|
$ | 从第一个字符(下标:0)开始取5个字符 | /dir1 |
$ | 从第6个字符(下标:5)开始取5个字符 | /dir2 |
$ | 将第一个dir替换成path | /path1/dir2/dir3/my.file.txt |
$ | 将全部dir替换成path | /path1/path2/path3/my.file.txt |
$ | 获取字符串长度 | 27 |
4、$()命令替换
$()和反引号``都是命令替换功能符号,反引号 (`) 位于键盘的Tab键的上方,1键的左方。注意与单引号(')位于Enter键的左方的区别。在Linux中起着命令替换的作用。命令替换是指shell能够将一个命令的标准输出插在一个命令行中任何位置。
[root@localhost home]# echo the date is `date` #shell会执行反引号中的date命令,把结果插入到echo命令中。
the date is Mon May 24 19:15:13 PDT 2021
[root@localhost home]#
注:在操作上,$()和反引号``都是达到相应的效果,但是建议使用$(),理由如下:
- ``很容易与''搞混乱。
- 在多层次的复合替换中,``必须要额外的跳脱处理(反斜线),而$( )比较直观。
示例: - 将cmd1执行结果作为cmd2参数,再将cmd2结果作为cmd3的参数
cmd3 $(cmd2 $(cmd1))
- 如果是用反引号,直接引用是不行的,还需要作跳脱处理
cmd3 `cmd2 \`cmd1\``
最后,$( )的弊端是,并不是所有的类unix系统都支持这种方式,但反引号是肯定支持的。
5、进行数学运算
$[] $(())它们是一样的,都是进行数学运算的。支持+ - * / %分别为 “加、减、乘、除、取模”。但是注意,bash只能作整数运算,对于浮点数是当作字符串处理的。(( ))及[[ ]]它们分别是[]的针对 数学比较表达式 和 字符串表达式 的加强版。
在** [[ ]]中增加了另一个特性:模式匹配。(( ))**,不需要再将表达式里面的大小于符号转义,除了可以使用标准的数学运算符外,还增加了以下符号: