Shell(1):变量和常用表达式

一、实现功能

二、变量

 1.自定义变量

2.环境变量

3.位置参数变量

4.预定义变量

三、Shelll常用表达式

1.逻辑连接符

2.运算

3. 内置判断测试

4.时间命令

四、参考


一、实现功能

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:表示第几个参数,将传入的参数保存在位置变量中,以便于在脚本中可以使用这些变量

#!/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
其中\是转义字符,代表$只是一个字符串

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 $?


三、Shelll常用表达式

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

四、参考

1.https://www.cnblogs.com/xd502djj/p/8963832.html

 

你可能感兴趣的:(shell)