一、实现功能
二、变量
1.自定义变量
2.环境变量
3.位置参数变量
4.预定义变量
三、Shelll常用表达式
1.逻辑连接符
2.运算
3. 内置判断测试
4.时间命令
四、参考
Shell变量和常用表达式在生产中经常用到,在此总结,加深一下记忆。
注意:变量对大小敏感;号两边不能有空格;中间有空格,需要用双引号引起: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
(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
(1)$n:表示第几个参数,将传入的参数保存在位置变量中,以便于在脚本中可以使用这些变量
#!/bin/bash
echo $0
echo $1
echo $2
echo $3
运行:
[root@hadoop sh]# ./parameter.sh 1 2 3
./parameter.sh
1
2
3
[root@hadoop sh]# ./parameter.sh 1 2 3 4 5 6
./parameter.sh
1
2
3
(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
其中\是转义字符,代表$只是一个字符串
(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 $?
(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
(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
备注:+两侧一定要有空格
(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 -》可写
(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
1.https://www.cnblogs.com/xd502djj/p/8963832.html