一、实现功能
Shell变量和常用表达式在生产中经常用到,在此总结,加深一下记忆。
二、变量
1.自定义变量
注意:变量对大小敏感;号两边不能有空格;中间有空格,需要用双引号引起:p2="test2 helloworld"
(1)变量定义
[root@hadoop sh]# p1=test1
[root@hadoop sh]# p2="test2 helloworld"
(2)变量拼接:$外部添加双引号
[root@hadoop sh]# p3="$p1""$p2"
[root@hadoop sh]# echo $p3
test1test2 helloworld
(3)变量调用
[root@hadoop sh]# echo $p1
test1
(4)所有变量查看set
[root@hadoop sh]# set | grep p1
p1=test1
(5)变量删除unset
[root@hadoop sh]# unset p2
[root@hadoop sh]# echo $p2
2.环境变量
(1) 声明环境变量:export
[root@hadoop sh]# export env1="ai ni yi wan nian"
[root@hadoop sh]# echo env1
env1
(2) 查询环境变量:env
[root@hadoop sh]# env | grep env1
env1=ai ni yi wan nian
(3) 删除环境变量unset
[root@hadoop sh]# unset env1
3.位置参数变量
(1)$n:表示第几个参数,将传入的参数保存在位置变量中,以便于在脚本中可以使用这些变量。0表示脚本名称
参考:https://www.jianshu.com/p/d3cd36c97abc
以及:https://www.runoob.com/linux/linux-shell-passing-arguments.html
#!/bin/bash
echo $0 # 当前脚本的文件名(间接运行时还包括绝对路径)。
echo $n # 传递给脚本或函数的参数。n 是一个数字,表示第几个参数。例如,第一个参数是 $1 。
echo $# # 传递给脚本或函数的参数个数。
echo $* # 传递给脚本或函数的所有参数。
echo $@ # 传递给脚本或函数的所有参数。被双引号 (" ") 包含时,与 $* 不同,下面将会讲到。
echo $? # 上个命令的退出状态,或函数的返回值。
echo $$ # 当前 Shell 进程 ID。对于 Shell 脚本,就是这些脚本所在的进程 ID。
echo $_ # 上一个命令的最后一个参数
echo $! # 后台运行的最后一个进程的 ID 号
echo ${@:2} # 从第2个开始取参数
运行
./input.sh 1 2 3 4 5
结果
./input.sh
5
1 2 3 4 5
1 2 3 4 5
0
55784
55784
2 3 4 5
(2)$*:命令行中所有运行参数和$#:运行参数地个数
[root@hadoop sh]# vi parameter2.sh
#!/bin/bash
echo $*
echo $#
运行
[root@hadoop sh]# ./parameter2.sh 1 2 3
1 2 3
3
(3)$@和$*区别
$* 和 $@ 都表示传递给函数或脚本的所有参数
-》不被双引号" "包含时:
都以"$1" "$2" … "$n" 的形式输出所有参数。
-》被双引号" "包含时:
"$*" 会将所有的参数作为一个整体,以"$1 $2 … $n"的形式输出所有参数;"$@" 会将各个参数分开,以"$1" "$2" … "$n" 的形式输出所有参数。
[root@hadoop sh]# vi parameter4.sh
#!/bin/bash
echo "\$*=" $*
echo "\"\$*\"=" "$*"
echo "\$@=" $@
echo "\"\$@\"=" "$@"
echo "print each param from \$*"
for var in $*
do
echo "$var"
done
echo "print each param from \$@"
for var in $@
do
echo "$var"
done
echo "print each param from \"\$*\""
for var in "$*"
do
echo "$var"
done
echo "print each param from \"\$@\""
for var in "$@"
do
echo "$var"
done
运行:
[root@hadoop sh]# ./parameter4.sh a b c d
$*= a b c d
"$*"= a b c d
$@= a b c d
"$@"= a b c d
print each param from $*
a
b
c
d
print each param from $@
a
b
c
d
print each param from "$*"
a b c d
print each param from "$@"
a
b
c
d
其中\是转义字符,代表$只是一个字符串
或者实例
#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com
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
4.预定义变量
(1)$?:检测上一条命令是对还是错
[root@hadoop sh]# ls /
bin dev etc lib lost+found misc net passwd root selinux sys usr
boot dump.rdb home lib64 media mnt opt proc sbin srv tmp var
[root@hadoop sh]# echo $0
-bash
[root@hadoop sh]# echo $?
0
[root@hadoop sh]# ls /lll666
ls: cannot access /lll666: No such file or directory
[root@hadoop sh]# echo $?
2
三、Shell常用表达式
1.逻辑连接符
(1)“A && B”:逻辑与,A执行成功,B才执行;A失败,B不执行
[root@hadoop sh]# ls /misf3fd && echo world
ls: cannot access /misf3fd: No such file or directory
[root@hadoop sh]# ls /root && echo world
anaconda-ks.cfg Documents install.log ml-100k.zip passwd Public somefile testfile.txt
Desktop Downloads install.log.syslog Music Pictures shell Templates Videos
world
(2)“A || B”:逻辑或,A成功,B不执行;A失败,B执行
例如:A失败,B执行
[root@hadoop sh]# ls /misf3fd || echo world
ls: cannot access /misf3fd: No such file or directory
world
A成功,B不执行
[root@hadoop sh]# ls /root || echo world
anaconda-ks.cfg Documents install.log ml-100k.zip passwd Public somefile testfile.txt
Desktop Downloads install.log.syslog Music Pictures shell Templates Videos
(3)分号”;” :无逻辑关系,顺序执行
[root@hadoop sh]# ls /misf3fd ; echo world
ls: cannot access /misf3fd: No such file or directory
world
2.运算
(1)中括号
[root@hadoop sh]# echo $[a+b]
7
[root@hadoop sh]# echo $[$a+$b]
7
[root@hadoop sh]# echo $[$a-$b]
-1
[root@hadoop sh]# echo $[a-b]
-1
(2)小括号
[root@hadoop sh]# echo $((a-b))
-1
[root@hadoop sh]# echo $(($a-$b))
-1
(3)表达式expr
[root@hadoop sh]# expr $a + $b
7
备注:+两侧一定要有空格
3. 内置判断测试
(1)字符串
==:相等,
!=:不等,
-z:如果字符串为空,则返回真,
-n:如果字符串不为空,则返回真.例如:
[root@hadoop sh]# [ $a == $b ]
[root@hadoop sh]# echo $?
1
备注:$?等于0,则为正确,不为0则为错误。
[root@hadoop sh]# [ $a != $b ]
[root@hadoop sh]# echo $?
0
[root@hadoop sh]# [ -z $a ]
[root@hadoop sh]# echo $?
1
返回1,证明a不为空。
(2)数字
eq等于
ne不等于
lt小于
le小于等于
gt大于
ge大于等于,例如:
[root@hadoop sh]# a=3;b=4
[root@hadoop sh]# [ $a -eq $b ]
[root@hadoop sh]# echo $?
1 -》a和b不相等
[root@hadoop sh]# [ $a -ne $b ]
[root@hadoop sh]# echo $?
0 -》a和b不相等
[root@hadoop sh]# [ $a -lt $b ]
[root@hadoop sh]# echo $?
0 -》a小于b
备注:!=等也可以
(3)文件
-e 文件名 :如果文件名存在即为真
-f: 文件名:文件存在,并且是一个普通文件,而不是目录,则返回真
-d 文件名: 判断文件是否存在,而且是一个目录,则返回真
-r 文件名: 如果文件名存在且可读则为真
-w 文件名: 如果文件名存在且可写则为真
-x 文件名 : 如果文件名存在且可执行则为真
[root@hadoop sh]# [ -e parameter.sh ]
[root@hadoop sh]# echo $?
0
[root@hadoop sh]# ll
total 16
-rwxr-xr-x. 1 root root 30 Nov 13 09:14 parameter2.sh
-rwxr-xr-x. 1 root root 37 Nov 13 09:16 parameter3.sh
-rwxr-xr-x. 1 root root 364 Nov 13 10:02 parameter4.sh
-rwxr--r--. 1 root root 45 Nov 13 08:49 parameter.sh
[root@hadoop sh]# [ -x parameter.sh ]
[root@hadoop sh]# echo $?
0 -》可执行
[root@hadoop sh]# [ -w parameter.sh ]
[root@hadoop sh]# echo $?
0 -》可写
4.时间命令
(1)查看当前系统时间
[root@hadoop sh]# date
Wed Nov 13 10:36:21 CST 2019
(2)设置时间
# date -s "2019-11-11 12:01:00"
(3)按照固定格式输出时间,使用”+”在+后面添加下列格式即可,
%H:小时(00-23)
%M:分钟(00-59)
%d:日(01-31)
%Y:完整年份(0000-9999)
%S:秒(00-60)
[root@hadoop sh]# date "+%Y-%m-%d"
2019-11-13
[root@hadoop sh]# date "+%y-%m-%d"
19-11-13
(4)昨天
$ date +"%Y%m%d" -d "+n days"
20190122
四、Shell 数组
1.Shell 概念
数组用括号来表示,元素用"空格"符号分割开,语法格式如下:
array_name=(value1 value2 ... valuen)
2.定义数组
#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com
my_array=(A B "C" D)
或者使用下标来定义数组:
array_name[0]=value0
array_name[1]=value1
array_name[2]=value2
3.读取数组
${array_name[index]}->获取数组中的某一个元素
实例
#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com
my_array=(A B "C" D)
echo "第一个元素为: ${my_array[0]}"
echo "第二个元素为: ${my_array[1]}"
echo "第三个元素为: ${my_array[2]}"
echo "第四个元素为: ${my_array[3]}"
执行脚本,输出结果如下所示:
$ chmod +x test.sh
$ ./test.sh
第一个元素为: A
第二个元素为: B
第三个元素为: C
第四个元素为: D
->获取数组中的所有元素
使用@ 或 * 可以获取数组中的所有元素,例如:
#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com
my_array[0]=A
my_array[1]=B
my_array[2]=C
my_array[3]=D
echo "数组的元素为: ${my_array[*]}"
echo "数组的元素为: ${my_array[@]}"
执行脚本,输出结果如下所示:
$ chmod +x test.sh
$ ./test.sh
数组的元素为: A B C D
数组的元素为: A B C D
4.获取数组的长度
获取数组长度的方法与获取字符串长度的方法相同,例如:
#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com
my_array[0]=A
my_array[1]=B
my_array[2]=C
my_array[3]=D
echo "数组元素个数为: ${#my_array[*]}"
echo "数组元素个数为: ${#my_array[@]}"
执行脚本,输出结果如下所示:
$ chmod +x test.sh
$ ./test.sh
数组元素个数为: 4
数组元素个数为: 4
五、参考
1.https://www.cnblogs.com/xd502djj/p/8963832.html