shell --Day 5

if语句格式:

 

语句格式:

1、单分支语句:

                      if 条件;then

                          执行语句

                      fi

                      只有条件为真时,才会去执行后面的执行语句;

2、双分支语句:

                       if 条件;then

                            执行语句1

                       else

                            执行语句2

                        fi

3、多分支语句:

                         if 条件1;then

                             执行语句1

                         elif 条件2;then

                              执行语句2                      

                         elif 条件3;then

 

                              执行语句3

                          ...
                          else
                               执行语句n
                           fi

实验部分:

1、判断/etc/inittab文件是否大于100行,如果大于,则显示”/etc/inittab is a big file.”否者显示”/etc/inittab is a small file.”

 

[root@lsl ~]vi 2.txt
#!/bin/bash
a=` wc -l /etc/inittab|cut -d ' ' -f1`
if [ $a -gt 100 ];then
echo '/etc/inittab is a big file.'
else
echo '/etc/inittab is small file.'
fi

 

2、给定一个用户,来判断这个用户是什么用户,如果是管理员用户,则显示“该用户为管理员”,否则显示“该用户为普通用户”

[root@lsl ~]vi 6.txt
#!/bin.bash
#
read -p "please input a user:" user
if id -u $1 &> /dev/null;then a=$(id -u $1) if [ $a -eq 0 ];then echo "$1 is a supper user" elif [ $a -ge 1 -a $a -lt 500 ];then echo "$1 is a system user" else echo "$1 is a ordinary user" fi else echo "$1 user not exist" fi

 

3、判断某个文件是否存在

[root@lsl ~]# vi 7.txt
#!/bin/bash
#
read -p "please input a file:" file
if [ -e $1];then if [ -f $1];then echo "file exists" else echo "$1 is exists but not a file" fi else echo "$1 does not exists" f

 

4、判断当前系统上是否有用户的默认shell程序是否为bash程序,如果有,就显示有多个这类用户,否则就显示没有这类用户

[root@lsl~]vi 5.txt
#!/bin/bash
#
grep "\<nologin\>" /etc/passwd &> /dev/null

if [ $? -eq 0 ];then
     echo "cunzai user"
     echo "nologin user such as:"
     grep "\<nologin\>" /etc/passwd | cut -d":" -f1
     echo "user total"
     grep "\<nologin\>" /etc/passwd | wc -l
else
     echo "shell user not exist"
fi

 

5、写出一个脚本程序,给定一个文件,比如:/etc/inittab a、判断这个文件中是否有空白行? b、如果有,则显示其空白行的行号,否则显示没有空白行

[root@lsl~]vi 4.txt
#!/bin/bash
#
if [ -f $1 ];then
   grep "^[[:space:]]*$" /tmp/inittab.bak &> /dev/null
   if [ $? -eq 0 ];then
         echo "space have:"
         grep -n "^[[:space:]]*$" /tmp/inittab.bak | cut -d":" -f1
         exit 0
   else
         echo "no such:"
         exit 1
   fi

else
         echo "file not exits,or not a file!"
         exit 2
fi

 

6、写一个脚本程序,判断其UID与GID是否一样,如果一样,就显示该用户为“good boy”

[root@lsl ~]# vi 8.txt  
#!/bin/bash
#
read -p "please input a user:" user ERNAME
=user1 USERID=`id -u $USERNAME` GROUPID=`id -g $USERNAME ` if [ $USERID -eq $GROUPID ];then echo "good boy" else echo "bad boy" fi

 

7、写一个脚本程序,给定一个用户,获取其密码警告期限;然后判断用户最近一次修改密码的时间距离今天是否已经小于警告期限

[root@lsl ~]# vi 9.txt  
#!/bin/bash
#
read -p "please input a user:" user W
=`grep "student" /etc/shadow | cut -d: -f6` S=`date +%s` T=`expr $S/86400` L=`grep "^student" /etc/shadow | cut -d: -f5` N=`grep "^student" /etc/shadow | cut -d: -f3` SY=$[$L-$[$T-$N]] if [ $SY -lt $W ]; then echo 'Warning' else echo 'OK' fi

 

8、判断命令历史中历史命令的总条目是否大于1000,如果大于,则显示“some command will gone”,否则显示OK

[root@lsl ~]# vi b.txt
#!/bin/bash
#
num=`history | wc -l`
if [ $num -gt 1000 ];then
    echo "some command will gone"
else
    echo "OK"
fi

 

9、给定一个文件,如果是普通文件,就显示出来,如果是目录文件,也显示出来,否则就显示“无法识别”

[root@lsl ~]# vi c.txt
#!/bin/bash
#
read -p "please input a file:" file
if [ -f $file ];then
   echo "Ordinary file"
elif [ -d $file ];then
   echo "Directory file"
else
   echo "can not Distinguish"
fi

 

10、写一个脚本,能接受一个参数(文件路径),判断这个参数如果是一个存在的文件就显示“ok”,否则显示“No such file"

[root@lsl ~]# vi d.txt
#!/bin/bash
#
read -p "please input a pash:" route
if [ -f $route ];then
   echo "ok"
else
   echo "No such file"
fi

 

11、写一个脚本,给脚本传递两个参数,显示两者之和和两者之积

[root@lsl ~]# vi e.txt  
#!/bin/bash
#
read -p "plesae input num1:" num1
read -p "please input num2:" num2
sum=$[$num1+$num2]
product=$[$num1*$num2]
      echo "$num1+$num2=$sum"
      echo "$num1"x"$num2=$product"

                       

posted @ 2019-09-22 17:05  Block翊树  阅读(179)  评论(0编辑  收藏  举报