``:命令的执行结果

$?:命令的执行状态结果


条件判断:
 如果用户不存在
  添加用户,给密码并显示添加成功;
 否则
  显示如果已经没在,没有添加;


bash中如何实现条件判断?
条件测试类型:
 整数测试
 字符测试
 文件测试


条件测试的表达式:
 [ expression ]
 ` expression `
 test expression



整数比较:
 -eq: 测试两个整数是否相等;比如 $A -eq $B

[rhel@localhost ~]$ a=3
[rhel@localhost ~]$ b=6

[rhel@localhost ~]$ echo $a
3
[rhel@localhost ~]$ echo $b
6

[rhel@localhost ~]$ [ $a -eq $b ]
[rhel@localhost ~]$ echo $b
6
[rhel@localhost ~]$


(表达式需要使用[ ])

 -ne: 测试两个整数是否不等;不等,为真;相等,为假;
 -gt: 测试一个数是否大于另一个数;大于,为真;否则,为假;
 -lt: 测试一个数是否小于另一个数;小于,为真;否则,为假;
 -ge: 大于或等于
 -le:小于或等于



命令的间逻辑关系:
 逻辑与: &&  (如果...就...,递进关系)
  第一个条件为假时,第二条件不用再判断,最终结果已经有;
  第一个条件为真时,第二条件必须得判断;

[rhel@localhost ~]$ id user1 &> /dev/null && echo "hello, world"
[rhel@localhost ~]$ echo $?
1
[rhel@localhost ~]$ id rhel &> /dev/null && echo "hello, world"
hello, world


如果用户user6不存在,就添加用户user6
! id user6 && useradd user6
id user6 || useradd user6


如果/etc/inittab文件的行数大于100,就显示好大的文件;
[ `wc -l /etc/inittab | cut -d' ' -f1` -gt 100 ] && echo "Large file."

[root@localhost ~]# nano second.sh
[root@localhost ~]#
[root@localhost ~]# chmod +x second.sh
[root@localhost ~]# ./second.sh
26 /etc/inittab
[root@localhost ~]#


逻辑或: || (否则,并列关系)

#!/bin/bash
lines=`wc -l /etc/inittab`
#echo $lines

num=`echo $lines | cut -d' ' -f1`
#echo $num

[ $num -gt 100 ] && echo "/etc/inittab is a big file." ||  echo "/etc/inittab is a small file."


[root@localhost ~]# ./second.sh
/etc/inittab is a small file.



如果用户存在,就显示用户已存在;否则,就添加此用户;
id user1 && echo "user1 exists." || useradd user1


如果用户不存在,就添加;否则,显示其已经存在;
! id user1 && useradd user1 || echo "user1 exists."


如果用户不存在,添加并且给密码;否则,显示其已经存在;
! id user1 && useradd user1 && echo "user1" | passwd --stdin user1 || echo "user1 exists."


练习,写一个脚本,完成以下要求:
1、添加3个用户user1, user2, user3;但要先判断用户是否存在,不存在而后再添加;
2、添加完成后,显示一共添加了几个用户;当然,不能包括因为事先存在而没有添加的;
3、最后显示当前系统上共有多少个用户;

练习1

[root@localhost ~]# cat user2.sh
#!/bin/bash
! id user1 &> /dev/null && useradd user1 && echo "user1" | passwd --stdin user1 &> /dev/null || echo "user1 exits."
! id user2 &> /dev/null && useradd user2 && echo "user2" | passwd --stdin user2 &> /dev/null || echo "user2 exits."
! id user3 &> /dev/null && useradd user3 && echo "user3" | passwd --stdin user3 &> /dev/null || echo "user3 exits."


usernum=`wc -l /etc/passwd | cut -d: -f1`
echo "$usernum users"
[root@localhost ~]# chmod +x user2.sh
[root@localhost ~]# ./user2.sh
35 /etc/passwd users
[root@localhost ~]#


练习2,写一个脚本,完成以下要求:
给定一个用户:
 1、如果其UID为0,就显示此为管理员;
 2、否则,就显示其为普通用户;

[root@localhost ~]# chmod +x third.sh
[root@localhost ~]# cat third.sh
#!/bin/bash


name=user1
userid=`id -u $name`
[ $userid -eq 0 ] && echo "$name is admin" || echo "$name is comman user"
[root@localhost ~]# ./third.sh
user1 is comman user
[root@localhost ~]#


练习3

[root@localhost ~]# !cat
cat third.sh
#!/bin/bash


name=root
userid=`id -u $name`
[ $userid -eq 0 ] && echo "$name is admin" || echo "$name is comman user"
[root@localhost ~]# ./third.sh
root is admin
[root@localhost ~]#



if语句,直接采用表达式的执行状态结果

if grep "bash$" /etc/passwd &> /dev/null; then


[root@localhost ~]# cat userexit.sh
#!/bin/bash


name=user17


if id $name &> /dev/null; then
 echo "$name exits."
else
 useradd $name
 echo $name | passwd --stdin $name &> /dev/null
 echo "add $name finished."
fi
[root@localhost ~]#


练习:写一个脚本
判断当前系统上是否有用户的默认shell为bash;
   如果有,就显示有多少个这类用户;否则,就显示没有这类用户;

[root@localhost ~]# cat bash.sh
#!/bin/bash

#

grep "\<bash$" /etc/passwd &> /dev/null
RETVAL=$?

if [ $RETVAL -eq 0 ]; then
 USERS=`grep "\<bash$" /etc/passwd | wc -l`
 echo "$USERS users shell"
else
 echo "No such user."
fi
[root@localhost ~]# ./bash.sh
7 users shell
[root@localhost ~]#

 


练习:写一个脚本
给定一个文件,比如/etc/inittab
判断这个文件中是否有空白行;
如果有,则显示其空白行数;否则,显示没有空白行。

[root@localhost ~]# ./bash1.sh
this is null
[root@localhost ~]# cat ./bash1.sh
#!/bin/bash
#
VAR=`grep "^$" /etc/passwd | wc -l`


if [ $VAR -eq 0 ]; then
 echo "this is null "
else
 echo "there are $VAR lines"
fi
[root@localhost ~]#


练习:写一个脚本
给定一个用户,判断其UID与GID是否一样
如果一样,就显示此用户为“good guy”;否则,就显示此用户为“bad guy”。

[root@localhost ~]# ./bash3.sh
root is good man
[root@localhost ~]# cat ./bash3.sh
#!/bin/bash
#
USER=root
USERID=`id -u $USER`
USERGID=`id -g $USER`


if [ $USERID -eq $USERGID ]; then
 echo "$USER is good man"
else
 echo "$USER is bad guy"
fi
[root@localhost ~]#




提示:“引用”一个命令的执行结果,要使用命令引用;比如: RESAULTS=`wc -l /etc/passwd | cut -d: -f1`;
      使用一个命令的执行状态结果,要直接执行此命令,一定不能引用;比如: if id user1一句中的id命令就一定不能加引号;
   如果想把一个命令的执行结果赋值给某变量,要使用命令引用,比如USERID=`id -u user1`;
      如果想把一个命令的执行状态结果保存下来,并作为命令执行成功与否的判断条件,则需要先执行此命令,而后引用其状态结果,如
  id -u user1
  RETVAL=$?
  此句绝对不可以写为RETVAL=`id -u user1`;





shell中如何进行算术运算:
A=3
B=6
1、let 算术运算表达式
 let C=$A+$B

[root@localhost ~]# a=3
[root@localhost ~]# b=6
[root@localhost ~]# c=$a+$b
[root@localhost ~]# echo $c
3+6
[root@localhost ~]# let c=$a+$b
[root@localhost ~]# echo $c
9
[root@localhost ~]#


2、$[算术运算表达式]
 C=$[$A+$B]

[root@localhost ~]# d=$[$a+$b]
[root@localhost ~]# echo $d
9
[root@localhost ~]#


3、$((算术运算表达式))
 C=$(($A+$B))

[root@localhost ~]# e=$(($a+$b))
[root@localhost ~]# echo $e
9
[root@localhost ~]#


4、expr 算术运算表达式,表达式中各操作数及运算符之间要有空格,而且要使用命令引用
 C=`expr $A + $B`

[root@localhost ~]# f=`expr $a + $b`
[root@localhost ~]# !echo
echo $f
9
[root@localhost ~]#


练习:写一个脚本
给定一个用户,获取其密码警告期限;
而后判断用户密码使用期限是否已经小于警告期限;
 提示:计算方法,最长使用期限减去已经使用的天数即为剩余使用期限;
如果小于,则显示“Warning”;否则,就显示“OK”。

[root@localhost ~]# cat ./timeout.sh
#!/bin/bash


modify=`tail -1 /etc/shadow | cut -d: -f3`
max=`tail -1 /etc/shadow | cut -d: -f5`
now=$[`date +%s`/86400]
let time=$max-$now+$modify
if [ $time -lt 7 ];then
 echo "warning!"
else
 echo "this's ok"
fi




写一个脚本:
计算100以内所有能被3整除的正整数的和;
取模,取余:%
3%2=1
100%55=45


写一个脚本,(自增/自减)
计算100以内所有奇数的和以及所有偶数的和;分别显示之;

let I=$[$I+1]
SUM=$[$SUM+$I]


let SUM+=$i


let i+=1 相当于 let i++


-=
 let i-=1 相当于 let i--
 
 ++i, --i


*=
/=
%=



[root@localhost ~]# cat sum.sh
#!/bin/bash


declare -i even=0
declare -i odd=0


for i in {1..100};do
 if [ $[$i%2] -eq 0 ];then
  even=$even+i
 else
  odd=$odd+i
 fi
done


echo "the even sum is :$even"
echo "the odd sum is :$odd"


[root@localhost ~]# bash sum.sh
the even sum is :2550
the odd sum is :2500
[root@localhost ~]#





 

定义脚本退出状态码


exit: 退出脚本
exit #
如果脚本没有明确定义退出状态码,那么,最后执行的一条命令的退出码即为脚本的退出状态码;



[root@localhost ~]# cat ./userexit.sh
#!/bin/bash

name=user16

if ! grep "^$name\>" /etc/passwd &> /dev/null;then
 echo "no such user: $name."
 exit 1
fi


if id $name &> /dev/null; then
 echo "$name exits."
else
 useradd $name
 echo $name | passwd --stdin $name &> /dev/null
 echo "add $name finished."
fi
[root@localhost ~]#


[root@localhost ~]# ./userexit.sh
user17 exits.



文件测试:(表达式需要[ ])
-e FILE:测试文件是否存在
-f FILE: 测试文件是否为普通文件
-d FILE: 测试指定路径是否为目录
-r FILE: 测试当前用户对指定文件是否有读取权限;
-w
-x 


[ -e /etc/inittab ]
[ -x /etc/rc.d/rc.sysinit ] 



[root@localhost ~]# nano file1.sh
[root@localhost ~]# chmod +x file1.sh
[root@localhost ~]# ./file1.sh
no blank line.
[root@localhost ~]# cat file1.sh
#!/bin/bash


FILE=/etc/inittab
if [ ! -e $FILE ]; then
 echo "no $FILE"
 exit 8
fi


if grep "^$" $FILE &> /dev/null; then
 echo "blank lines:`grep "^$" $FILE | wc -l`. "
else
 echo "no blank line."
fi
[root@localhost ~]#



多分支的if语句:
if 判断条件1; then
  statement1
  ...
elif 判断条件2; then
  statement2
  ...
elif 判断条件3; then
  statement3
  ...
else
  statement4
  ...
fi

[root@localhost ~]# nano file2.sh
[root@localhost ~]#
[root@localhost ~]# chmod +x file2.sh
[root@localhost ~]# ./file2.sh
comman file
[root@localhost ~]# cat file2.sh
#!/bin/bash


FILE=/etc/rc.d/rc.sysinit


if [ ! -e $FILE ]; then
 echo "no such file."
 exit 7
fi


if [ -f $FILE ]; then
 echo "comman file"
elif [ -d $FILE ];then
 echo "directory"
else
 echo "unknow"
fi
[root@localhost ~]#



[root@localhost ~]# ./file2.sh
no such file.
[root@localhost ~]# echo $?
7
[root@localhost ~]# cat ./file2.sh
#!/bin/bash


FILE=/rc.sysinit


if [ ! -e $FILE ]; then
 echo "no such file."
 exit 7
fi


if [ -f $FILE ]; then
 echo "comman file"
elif [ -d $FILE ];then
 echo "directory"
else
 echo "unknow"
fi
[root@localhost ~]#



bash变量的类型:
 本地变量(局部变量)
 环境变量
 位置变量:
  $1, $2, ...
  shift
 特殊变量:
  $?:上一次命令的退出状态码
  $#:参数的个数
  $*: 参数列表
  $@:参数列表
 $0:脚本路径及名称

练习:写一脚本
能接受一个参数(文件路径)
判定:此参数如果是一个存在的文件,就显示“OK.”;否则就显示"No such file."

[root@localhost ~]# nano file3.sh
[root@localhost ~]#
[root@localhost ~]# chmod +x file3.sh
[root@localhost ~]# ./file3.sh /etc/fstab
ok
[root@localhost ~]# ./file3.sh /etc/fstabb
no such file
[root@localhost ~]# cat file3.sh
#!/bin/bash


if [ -e $1 ];then
 echo "ok"
else
 echo "no such file"
fi
[root@localhost ~]#


练习:

[root@localhost ~]# ./file3.sh /etc/fstabb
1
no such file
[root@localhost ~]# ./file3.sh /etc/fstab
1
ok
[root@localhost ~]# ./file3.sh /etc/fstab /etc/inittab
2
ok
[root@localhost ~]# ./file3.sh /etc/fstab /etc/inittab /etc
3
ok

[root@localhost ~]# cat ./file3.sh
#!/bin/bash


echo $#
if [ -e $1 ];then
 echo "ok"
else
 echo "no such file"
fi
[root@localhost ~]#


练习:

[root@localhost ~]# ./file3.sh
usage:./file3.sh ARG1 [ARG2...]
[root@localhost ~]# ./file3.sh /etc/abc
no such file
[root@localhost ~]# ./file3.sh /etc/inittab
ok
[root@localhost ~]# cat file3.sh
#!/bin/bash


if [ $# -lt 1 ];then
 echo "usage:./file3.sh ARG1 [ARG2...]"
 exit 8
fi


if [ -e $1 ];then
 echo "ok"
else
 echo "no such file"
fi
[root@localhost ~]#