经常使用的bsh算术运算方法
node
1.$[expression]:其中的表达式能够是纯数字组成的,也可使用变量引用变量值git
[root@localhost ~]# echo $[3+9*3] 30 在引用变量时,能够不使用引用符 [root@localhost ~]# int1=3 [root@localhost ~]# int2=9 [root@localhost ~]# echo $[int1+int2*int1] 30
2.let VAR=EXPRESSION 根据算术表达式完成算术运算并赋值给指定的变量shell
[root@localhost ~]# let int1=$[int1+int2*int1] [root@localhost ~]# echo $int1 30
3.$((EXPRESSION)) 其中的表达式能够是纯数字组成的,也可使用变量引用变量值;在使用变量时,能够将$符号省略,至关于$[expression]express
4.expr ARGU1 ARGU2 ARGU3 其中ARGU1 和 ARGU3必须是整数数值 ARGU2是算术运算符bash
[root@localhost ~]# expr 3 + 5 8 [root@localhost ~]# expr 3+5 3+5 [root@localhost ~]# expr 3 + 5 8 [root@localhost ~]# expr 3.3 + 5
注意:整数和符号之间须要有空格
5.echo "EXPRESSION" | bc 将echo输出的结果传送给计算器处理less
[root@localhost ~]# echo "33+5"|bc 38
6.bc <<<EXPRESSIONsocket
[root@localhost ~]# bc <<<33+5 38
条件测试命令:ide
test命令或 [ 命令测试
注意:此类条件测试命令,通常没有执行结果,只有执行状态返回值;其返回值为0;表示ture,其返回值为1为false 编码
1.数值测试:双目操做:
测试操做符:
-eq //(equal):测试俩个数值是否相等,等为0,不等为1
[root@localhost ~]# [ 3 -eq 4 ] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]# [ 3 -eq 3 ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]#
-ne //(not equal):测试俩个数值是否不等,等为1,不等为0
[root@localhost ~]# [ 3 -ne 3 ] [root@localhost ~]# $? bash: 1: 未找到命令...
-lt //(less than):小于,测试左边数值是否小于右边的数值,小为0,不小为1
[root@localhost ~]# [ 2 -lt 3 ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [ 4 -lt 3 ] [root@localhost ~]# $? bash: 1: 未找到命令...
-gt //(greater than):大于,测试左边数值是否大于右边的数值,大为0,不大为1
[root@localhost ~]# [ 2 -gt 3 ] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]# [ 4 -gt 3 ] [root@localhost ~]# $? bash: 0: 未找到命令...
-le //(less equal):小于等于,测试左边数值是否不大于右边数值,不大于为0,大于为1
[root@localhost ~]# [ 4 -le 4 ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [ 5 -le 4 ] [root@localhost ~]# $? bash: 1: 未找到命令...
-ge //(greater equal):大于等于,测试左边数值是否不小于右边数值,不小于为0,小于为1
[root@localhost ~]# [ 4 -ge 4 ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [ 3 -ge 4 ] [root@localhost ~]# [root@localhost ~]# $? bash: 1: 未找到命令...
注意:bash仅支持整数,不支持浮点数
2.字符串测试:
双目测试:
==|=: 测试俩个字符串是否为相同的字符串,相同为真,不一样为假
[root@localhost ~]# [ expr == expr ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [ expr1 == expr ] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]#
!=:测试俩个字符串是否为不一样的字符串,不一样为真,相同为假
[root@localhost ~]# [ expr1 != expr ] [root@localhost ~]# $? bash: 0: 未找到命令...
> :测试左边的字符串所对应的ASCII编码是否比右边字符串对应的ASCII编码大;大于为真,小于为假
<:测试左边的字符串所对应的ASCII编码是否比右边字符串对应的ASCII编码小;小于为真,大于为假
[root@localhost ~]# [[ a<b ]] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [[ a>b ]] [root@localhost ~]# $? bash: 1: 未找到命令...
STRING =~:测试左边的字符串可否被右边的PATTERN匹配,匹配为真,不能匹配为假
[root@localhost ~]# [[ string =~ [[:digit:]] ]] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]# [[ string =~ [^[:digit:]] ]] [root@localhost ~]# $? bash: 0: 未找到命令...
注意:>,<,=~这三类操做符只能用在[[ expr ]]测试语句中
单目测试:
-z 'STRING' :测试string是否为空串,空串为真,不空为假
-n 'STRING' :测试string是否为不空串,不空为真,空为假
[root@localhost ~]# [ -z 'nothing' ] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]# [ -n 'nothing' ] [root@localhost ~]# $? bash: 0: 未找到命令...
注意:1.一般状况下,字符串是须要引号引用的,单引号和双引号均可以,只有在特定的场合和特定的状况下,只能选用
单引号和双引号之一;
2.[]和[[]]在某些状况下,意义不彻底相同,要区分对待
3.若是使用[]和[[]]进行判断,在表达式的两边都留有空白字符,以区分命令和参数之间的关系
4.全部的双目测试操做符和参数之间也要留有空白字符
3.文件测试
单目测试 : //a.txt为普通文本文件, /etc为目录
-a|-e :测试普通文件是否存在,存在为真,不存在为假
[root@localhost ~]# [ -a a.txt ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [ -a abcabcaca ] [root@localhost ~]# $? bash: 1: 未找到命令...
-b :FILE exists and is block special:测试文件是否存在且为块设备文件,存在且为块设备为真,不然为假
-c :FILE exists and is character special:测试文件是否存在且为字符设备文件,存在且为字符设备为真,不然为假
-d :FILE exists and is a directory测试文件是否存在且是一个目录,存在且为目录文件为真,不然为假
[root@localhost ~]# [ -d a.txt ] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]# [ -d /etc ] [root@localhost ~]# $? bash: 0: 未找到命令...
-f :FILE exists and is a regular file测试文件是否存在且为普通文件,存在且为普通文件为真,不然为假
[root@localhost ~]# [ -f a.txt ] [root@localhost ~]# $? bash: 0: 未找到命令... [root@localhost ~]# [ -f /etc ] [root@localhost ~]# $? bash: 1: 未找到命令...
-h|-l :FILE exists and is a symbolic link测试文件是否存在且为符号连接文件,存在且为符号连接文件为真,不然为假
-s :FILE exists and has a size greater than zero测试文件是否存在且大小大于0,存在大小为0为真,不然为假 //3文件的大小为0
[root@localhost ~]# [ -s 3 ] [root@localhost ~]# $? bash: 1
-S :FILE exists and is a socket测试文件是否存在且为套接字文件,存在且为套接字文件为真,不然为假
-t :file descriptor FD is opened on a terminal测试文件是否存在且是否在终端被打开,存在且被终端打开为真,不然为假
-r :测试文件是否存在且当前用户是否被授予读取权限,存在且受权为真,不然为假
-w :测试文件是否存在且当前用户是否被授予写权限,存在且受权为真,不然为假
-x :测试文件是否存在且当前用户是否被授予执行或搜索权限,存在且受权为真,不然为假
[root@localhost ~]# ll b.sh -rw-r--r--. 1 root root 15 11月 9 19:59 b.sh [root@localhost ~]# [ -r b.sh ] [root@localhost ~]# echo $? 0 [root@localhost ~]# [ -w b.sh ] [root@localhost ~]# echo $? 0 [root@localhost ~]# [ -x b.sh ] [root@localhost ~]# echo $? 1
-u :测试文件是否存在且设置了SUID,存在且受权为真,不然为假
[root@localhost ~]# [ -u b.txt ] [root@localhost ~]# $? bash: 1: 未找到命令... [root@localhost ~]# chmod u+s b.txt [root@localhost ~]# [ -u b.txt ] [root@localhost ~]# $? bash: 0: 未找到命令...
-g :测试文件是否存在且设置了SGID,存在且受权为真,不然为假
[root@localhost ~]# chmod g+s b.sh [root@localhost ~]# [ -g b.sh ] [root@localhost ~]# echo $? 0
-k :测试文件是否存在且设置了STICKY,存在且受权为真,不然为假
[root@localhost ~]# chmod o+t b.sh [root@localhost ~]# [ -k b.sh ] [root@localhost ~]# echo $? 0
文件的全部权测试
-O :测试文件是否存在且属主为当前有效用户,存在且属主为当前有效用户为真,不然为假
[root@localhost ~]# [ -O a.txt ] [root@localhost ~]# echo $? 1 [root@localhost ~]# [ -O b.sh ] [root@localhost ~]# echo $? 0
-G :测试文件是否存在且属组为当前有效用户的所在组,存在且属组为当前有效用户的所在组为真,不然为假
[root@localhost ~]# [ -G a.txt ] [root@localhost ~]# echo $? 1 [root@localhost ~]# [ -G b.sh ] [root@localhost ~]# echo $? 0
双目测试:
FILE1 -ef FILE2 :测试俩个文件是否拥有相同的Inode编号;即:俩个文件是否互为硬件链接;
测试语句中添加逻辑运算符号
1.利用bash的逻辑运算符号运算
[ expr ] && [ expr ]
[ expr ] || [ expr ]
![ expr ]
2.利用条件测试命令自己的逻辑运算符号
[ expr1 -a expr2 ]
[ expr1 -o expr2 ]
[ !expr1 ]
命令的执行结果:
1.命令的正常输出结果
2.命令的执行状态返回值
0-255
0:表示命令成功执行或者条件判断为真
1-255:表示命令执行失败或者条件判断为假
1,2,127 :系统默认保留的
3-126,128-255 :用户自定义的
exit命令:
exit the shell
格式:exit [n]
退出shell时,使用n做为状态返回值,若是没有指定n,则默认的状态返回值为最后一条命令的状态返回值
注意:
当shell脚本运行时,一旦遇到exit命令,将当即结束运行此脚本的shell进程,同时此脚本的运行也会中止,
其后续的全部命令都不会再被解释执行;所以,包含了exit命令的脚本,不要用source命令执行