示例: -d:这是一个目录
[root@localhost ~]# test -d /home [root@localhost ~]# echo $? 0 [root@localhost ~]# test -d /home11111 [root@localhost ~]# echo $? 1 [root@localhost ~]# [ -d /home ]注意中括号里的两个空格 “!”取反
[root@localhost ~]# [ ! -d /ccc ] && mkdir /ccc [root@localhost ~]# [ -d /ccc ] || mkdir /ccc操作符种类: -f filename : 当filename 存在时返回真 -b filename : 当filename 存在并且是块文件时返回真(返回0) -d pathname : 当pathname 存在并且是一个目录时返回真 -h filename : 当filename 存在并且是符号链接文件时返回真 (或 -L filename) -u pathname : 当由pathname 指定的文件或目录存在并且设置了SUID 位时返回真 -c filename : 当filename 存在并且是字符文件时返回真 -e pathname : 当由pathname 指定的文件或目录存在时返回真 -g pathname : 当由pathname 指定的文件或目录存在并且设置了SGID 位时返回真 -k pathname : 当由pathname 指定的文件或目录存在并且设置了"粘滞"位时返回真 -p filename : 当filename 存在并且是命名管道时返回真 -r pathname : 当由pathname 指定的文件或目录存在并且可读时返回真 -s filename : 当filename 存在并且文件大小大于0 时返回真 -S filename : 当filename 存在并且是socket 时返回真 -t fd : 当fd 是与终端设备相关联的文件描述符时返回真 -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 旧时返回真
操作符: [ 1 -gt 10 ] 大于 [ 1 -lt 10 ] 小于 [ 1 -eq 10 ] 等于 [ 1 -ne 10 ] 不等于 [ 1 -ge 10 ] 大于等于 [ 1 -le 10 ] 小于等于
示例:
num=$(id -u) if [ $num -eq 0 ] then echo "administrator" else echo "user" fiC语言风格类型:
[root@localhost ~]# ((1<2));echo $? 0 [root@localhost ~]# ((1==2));echo $? 1 [root@localhost ~]# ((1>2));echo $? 1 [root@localhost ~]# ((1>=2));echo $? 1 [root@localhost ~]# ((1<=2));echo $? 0 [root@localhost ~]# ((1!=2));echo $? 0 [root@localhost ~]# ((`id -u`>0));echo $? 1 [root@localhost ~]# (($UID==0));echo $? 0-z:判断字符长度是为0 -n: 判断字符长度不是为0
双引号的重要性,解决一元表达式的问题 [root@localhost ~]# BBB="" [root@localhost ~]# echo ${#BBB} 0 [root@localhost ~]# [ -z "$BBB" ] 字符长度是为0 [root@localhost ~]# echo $? 0 [root@localhost ~]# [ -n "$BBB" ] 字符长度不为0 [root@localhost ~]# echo $? 1 双引号的重要性 定义三个变量,一个有值,一个妹纸,一个没有定义。 [root@localhost ~]# var1=111 [root@localhost ~]# var2= //var3变量没有定义 -z:判断长度是0 [root@localhost ~]# [ -z "$var1" ];echo $? 1 [root@localhost ~]# [ -z "$var2" ];echo $? 0 [root@localhost ~]# [ -z "$var3" ];echo $? 0 -n:判断长度不是0 [root@localhost ~]# [ -n "$var1" ];echo $? 0 [root@localhost ~]# [ -n "$var2" ];echo $? 1 [root@localhost ~]# [ -n "$var3" ];echo $? 1变量为空 或 未定义: 长度都为0
逻辑的(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 $? 0elif 条件测试2 then 命令序列
elif 条件测试3 then 命令序列…
else 命令序列 fi
示例:编写脚本,取出系统时间的小时,对数字进行判断 6–10 this is morning 11-13 this is noon 14-18 this is afternoon 其他 this is night #!/bin/bash # hour=`date +%H` if [ $hour -ge 6 -a $hour -le 10 ];then echo "This is morning" elif [ $hour -ge 11 -a $hour -le 13 ];then echo "This is noon" elif [ $hour -ge 14 -a $hour -le 18 ];then echo "This is afternoon" else echo "This is night" fi语法 if 条件测试1 then 命令序列 if 条件测试1 then 命令序列
else 命令序列 fi
else 命令序列 fi
示例 read -p "Input username: " name id $name &> /dev/null if [ $? -eq 0 ];then echo "$name 存在" else useradd $name echo "$name create finished" # echo "123456" | passwd --stdin $name &> /dev/null read -p "请输入用户密码: " pass if [ ${#pass} -ge 7 ];then echo "$pass" | passwd --stdin $name echo "$name 用户密码是 $pass" else echo "密码不合格" fi fi邀请用户输入待删除用户名。 询问用户,确定要继续删除吗 yes/no: " y
#!/bin/bash #name #time #1请输入删除的用户名: read -p "please input a username : " user #2输出用户ID id $user &> /dev/null #4判断用户是否存在 if [ $? -ne 0 ];then echo "no such user: $user" exit 1 fi case "$action" in Y|y|YES|yes) userdel -r $user echo "$user is deleted!" ;; *) echo "thank you" ;; Esac请选择要连接的主机[1-3]: 1
Last login: Sun Sep 6 04:18:01 2015 from 192.168.122.1 [yang@yang1 ~]$ ip a show eth0 2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000 link/ether 52:54:00:ea:e7:d1 brd ff:ff:ff:ff:ff:ff inet 192.168.122.186/24 brd 192.168.122.255 scope global eth0 inet6 fe80::5054:ff:feea:e7d1/64 scope link valid_lft forever preferred_lft forever
示例 #!/usr/bin/bash #定义目标主机IP web1=192.168.122.152 web2=192.168.122.128 mysql1=192.168.122.88 #跳转菜单不退出 while : do #打印跳转菜单 cat <<EOF 1.WEB1 2.WEB2 3.MYSQL1 EOF #读取用户输入 read -p "input number: " num #判断用户选择 case $num in 1) ssh alice@$web1 ;; 2) ssh alice@$web2 ;; *) echo '123' esac doneCommand (h for help): m total used free shared buffers cached Mem: 7628 840 6788 0 29 378 Swap: 2047 0 2047
示例 #!/usr/bin/bash #打印菜单 cat <<-EOF h. help f. disk partation d. filesystem mount m. memory u. system load q.exit EOF # 读取用户输入,进行模式匹配 read -p "please input [h for help]: " action case "$action" in f) fdisk -l ;; d) df -hT ;; m) free -m ;; u) uptime ;; q) exit ;; "") ;; *) echo "error" ;; Esac