shell 判断

一、条件测试

1、格式

      格式1: test 条件表达式

      格式2: [ 条件表达式 ]

      格式3: [[ 条件表达式 ]]

2、分类

     ① 字符串比较

    =,==,等于 

[root@localhost ~]# [ "$USER" = "root" ];echo $?
0
[root@localhost ~]# [ "$USER" == "root" ];echo $?
0
判断$USER变量是不是root,成功
[root@localhost ~]# [ "$USER" = "root" ];echo $?
0
判断变量是不是r开头,失败,为什么?[]无法使用正则
[root@localhost ~]# [  "$USER"   =~  ^r  ];echo $?
bash: [: =~: binary operator expected
2
语法正确,成功。因为条件测试中涉及正则需要[[ ]],不可使用[ ]
[root@localhost ~]# [[ "$USER" =~ ^r ]];echo $?
0

       !=,不等于

[root@localhost ~]# [ "$USER" = "root" ];echo $?
0
[root@localhost ~]# [ "$USER" = "alice" ];echo $?
1
[root@localhost ~]# [ "$USER" != "alice" ];echo $?
0

        -z:判断字符长度是为0
        -n: 判断字符长度不是为0

        变量为空 或 未定义: 长度都为0

         ② 数值比较

        [ 1 -gt 10 ] 大于
        [ 1 -lt 10 ] 小于
        [ 1 -eq 10 ] 等于
        [ 1 -ne 10 ] 不等于
        [ 1 -ge 10 ] 大于等于
        [ 1 -le 10 ] 小于等于

      ③文件测试

-b filename : 当filename 存在并且是块文件时返回真(返回0)
-c filename : 当filename 存在并且是字符文件时返回真
-d pathname : 当pathname 存在并且是一个目录时返回真
-e pathname : 当由pathname 指定的文件或目录存在时返回真
-f filename : 当filename 存在时返回真
-g pathname : 当由pathname 指定的文件或目录存在并且设置了SGID 位时返回真
-h filename : 当filename 存在并且是符号链接文件时返回真 (或 -L filename)
-k pathname : 当由pathname 指定的文件或目录存在并且设置了"粘滞"位时返回真
-p filename : 当filename 存在并且是命名管道时返回真
-r pathname : 当由pathname 指定的文件或目录存在并且可读时返回真
-s filename : 当filename 存在并且文件大小大于0 时返回真
-S filename : 当filename 存在并且是socket 时返回真
-t fd       : 当fd 是与终端设备相关联的文件描述符时返回真
-u pathname : 当由pathname 指定的文件或目录存在并且设置了SUID 位时返回真
-w pathname : 当由pathname 指定的文件或目录存在并且可写时返回真
-x pathname : 当由pathname 指定的文件或目录存在并且可执行时返回真
-O pathname : 当由pathname 存在并且被当前进程的有效用户id 的用户拥有时返回真(字母O 大写)
-G pathname : 当由pathname 存在并且属于当前进程的有效用户id 的用户的用户组时返回真
file1 -nt file2 : file1 比file2 新时返回真
file1 -ot file2 : file1 比file2 旧时返回真

      ④and和or

                            逻辑的(and)与(or)

                            &&   逻辑的 AND 的意思, -a 也是这个意思,两个条件同时成立,为真。

                            ||  逻辑的 OR 的意思, -o 也是这个意思,两个条件一个成立,为真。

[root@localhost ~]# [ 1 -lt 2 -a 5 -gt 10 ];echo $?
1
[root@localhost ~]# [ 1 -lt 2 -o 5 -gt 10 ];echo $?
0
注意:&&调用正则时,请使用双中括号。
[root@localhost ~]# [[ 1 -lt 2 && 5 -gt 10 ]];echo $? 
1
[root@localhost ~]# [[ 1 -lt 2 || 5 -gt 10 ]];echo $? 
0

或者
[root@localhost ~]# [ 1 -lt 2 ] && [ 11 -gt 10 ];echo $? 
0

二、流程控制(if)

1、单分支结构

             语法:if 条件测试;then 命令序列
                               fi

2、双分支结构

       语法:if 条件测试  ;  then
           命令序列
        else 命令序列
        fi

3、多分支结构

     语法:if 条件测试1;
        then 命令序列

        elif 条件测试2;
        then 命令序列

        elif 条件测试3;
        then 命令序列...

        else 命令序列
        fi

4、嵌套结构

     语法:if 条件测试1 ;  then
             if 条件测试1  ;  then 命令序列

             else 命令序列
             fi
    
        else 命令序列
        fi

三、模式匹配(case)

  语法:case 变量 in
     模式1)
     命令序列1
     ;;
     模式2)
     命令序列2
     ;;
     模式3)
     命令序列3
     ;;
     *)
     无匹配后命令序列
     esac

字符总结:

() 子shell中执行:		(cd /home;ls)
(()) 比较数值,运算 C语言:	((1<2));echo $?
$() 命令替换,或者反撇``:	touch file$(date)
$(()) 整数运算:			echo $((1+1))

{}集合:			touch file{1..3}
${}字符串的提取和替换。:	echo ${aaa-111}

[] 条件测试:			[ -f file1.txt ]; echo $?
[[]] 条件测试,支持正则 :	[[ 12 =~ [0-9]+$  ]] ;echo $?
$[] 整数运算:			echo $[1+1]

概念总结:

执行脚本:
# ./01.sh <需要执行权限> 在子shell中执行
# bash 01.sh 不需要执行权限 在子shell中执行

# . 01.sh 不需要执行权限 在当前shell中执行
# source 01.sh 不需要执行权限 在当前shell中执行
提示:通常修改系统配置文件中如 /etc/profile 的PATH等变量后,使之在当前shell中生效

调试脚本的其他方法:
# sh -n 02.sh 仅调试脚本中的语法错误。
# sh -vx 02.sh 以调试的方式执行,查询整个执行过程

 

你可能感兴趣的:(shell)