一、条件判断表达式                                                         

条件测试类型:

  • 整数测试
  • 字符测试
  • 文件测试

条件测试的表达式

  [ expression ](注意expression头和尾部各有一个空格)

  [[ expression ]]

  test expression

算术运算有三种方法:

  • let 算术运算表达式
  • $[算术运算表达式]
  • $((算术运算表达式))
  • expr 算术运算表达式
[root@hao ~]# A=
[root@hao ~]#
B=
[root@hao ~]#
let C=$A+$B
[root@hao ~]# echo $C

[root@hao ~]#
D=$[$A+$B]
[root@hao ~]# echo $D

[root@hao ~]#
E=$(($A+$B))
[root@hao ~]# echo $E

[root@hao ~]#
F=`expr $A + $B`
[root@hao ~]# echo $F

1、整数测试:

  -eq:测试两个整数是否相等 $A -eq $ eB。

[root@hao ~]# A=
[root@hao ~]#
B=
[root@hao ~]#
[ $A -eq $B ]
[root@hao ~]# echo $?

  -ne:测试两个整数是否不等

  -gt:测试一个数是否大于另一个数

  -lt:小于

  -ge:大于等于

  -le:小于或等于

语句间的逻辑关系(短路操作)

  逻辑与、逻辑或

下面代码实现逻辑与,如果用户存在,则第一个语句为TRUE,则执行第二个语句。否则,若用户不存在,即第一个语句为false,则该逻辑与结果必为false,因此第二个语句就不会执行

[root@hao ~]# id user1 &> /dev/null && echo "hello,test true"
[root@hao ~]#
id hao &> /dev/null && echo "hello,test true"
hello,test true

(1)如果用户不存在,则添加用户(用逻辑与、逻辑或两种方法实现)

[root@hao ~]# id user2
id: user2: No such user
[root@hao ~]# id user2 &> /dev/null || useradd user2
[root@hao ~]# id user2
uid=(user2) gid=(user2) groups=(user2)
[root@hao ~]# id user3
id: user3: No such user
[root@hao ~]# ! id user3 &> /dev/null && useradd user3
[root@hao ~]# id user3
uid=(user3) gid=(user3) groups=(user3)

(2)如果一个文件的行数大于100,则显示该文件为大文件,否则显示为小文件

#!/bin/bash
LINES=$(wc -l /etc/inittab)
echo $LINES
FINLINES=`echo $LINES |cut -d' ' -f1`
echo $FINLINES
[ $FINLINES -gt ]&& echo "etc/inittab is a big file" || echo "etc/inittab is a small file"

执行结果为:

 /etc/inittab

etc/inittab is a small file

(3)如果用户存在,则显示该用户,如果用户不存在,则添加此用户

[root@hao ~]# id user1 && echo "user1 exits." || useradd user1
uid=(user1) gid=(user1) groups=(user1)
user1 exits.

(4)如果用户不存在,则添加用户并添加密码,如果存在,则显示用户已存在

[root@hao ~]# ! id user1 && useradd user1 && echo "user1" | passwd --stdin user1 || echo "user1 exits"
uid=(user1) gid=(user1) groups=(user1)
user1 exits

(5)给定一个用户,如果其UID为0,则显示为管理员,否则显示为普通用户

[root@hao ~]# nano third.sh
[root@hao ~]#
cat third.sh
#!/bin/bash
NAME=user1
USERID=`id -u $NAME`
[ $USERID -eq ] && echo "Admin" || echo "Common user".
[root@hao ~]# chmod +x third.sh
[root@hao ~]#
./third.sh
Common user.

 2、文件测试

  -e file :测试文件是否存在

  -f file :测试文件是否为普通文件

  -d file:测试指定路径是否为目录

  -r file:测试指定文件对当前用户是否可读

  -w file:测试指定文件对当前用户是否可写

  -x file:测试指定文件对当前用户是否可执行

(1)判断一个文件是否存在

#!bin /bash
FILE=/etc/inittab
if [ ! -e $FILE ]
then
echo "no file"
exit
fi

(2)给定一个文件,如果不存在,则退出脚本,如果存在且该文件为普通文件或者目录就显示之,否则,

#!/bin/bash
FILE=/etc/rc.d/rc.sysinit if [ ! -e $FILE ]
then
echo "no file"
exit
fi if [ -f $FILE ]
then
echo "common file"
elif [ -d $FILE ]
then
echo "directory"
else
echo "unknown"
fi

二、条件判断控制结构                                                    

1、单分支if语句:

if 判断条件

then

  statement1

  statement2

  ...

fi

2、双分支的if语句

if 判断语句

then

  statement1

  statement2

else

  statement3

  statement4

fi

3、多分支的if语句

if 判断条件1

then

  statement1

  ...

elif 判断条件2

then

  statement2

  ...

elif 判断条件3

then

  statement3

  ...

else

  statement4

  ...

fi

4、测试

(1)如果用户存在,输出用户存在,否则创建用户名和密码为用户名的密码。

[root@hao ~]# nano fourth.sh
[root@hao ~]#
cat fourth.sh
#!/bin/bash
NAME=user4
if id $NAME &> /dev/null
then
echo "$NAME exists"
else
useradd $NAME
echo $NAME | passwd --stdin $NAME &> /dev/null
echo "add user successful"
fi
[root@hao ~]#
chmod +x fourth.sh
[root@hao ~]#
./fourth.sh
add user successful
[root@hao ~]# ./fourth.sh
user4 exists

(2)判断一个用户是否是管理员

[root@hao ~]# nano fifth.sh
[root@hao ~]#
cat fifth.sh
#!/bin/bash
NAME=user1
if [ `id -u $NAME ` -eq ]
then
echo "Admin"
else
echo "Common"
fi
[root@hao ~]#
chmod +x fifth.sh
[root@hao ~]#
./fifth.sh
Common

(3)判断当前系统上是否有用户的默认shell为bash,如果有,就显示有多少个这类用户,否则,就显示没有这类用户

[root@hao ~]# nano sixth.sh
[root@hao ~]#
cat sixth.sh
#!/bin/bash
grep "\<bash$" /etc/passwd &> /dev/null
RETVAL=$?
if [ $RETVAL -eq ]
then
USERS=`grep "\<bash$" /etc/passwd | wc -l`
echo "$USERS users has shell of bash"
else
echo "no such users"
fi
[root@hao ~]#
chmod +x sixth.sh
[root@hao ~]#
./sixth.sh
users has shell of bash

(4)上题基础上,如果存在上述用户,显示其中一个的用户名,否则显示没有此类用户

[root@hao ~]# nano seventh.sh
[root@hao ~]#
cat seventh.sh
#!/bin/bash
grep "\<bash$" /etc/passwd &> /dev/null
RETVAL=$?
if [ $RETVAL -eq ]
then
AUSER=`grep "\<bash$" /etc/passwd | head - | cut -d: -f1`
USERS=`grep "\<bash$" /etc/passwd | wc -l`
echo "One of the $USERS is $AUSER" else
echo "no such users"
fi
[root@hao ~]#
chmod +x seventh.sh
[root@hao ~]#
./seventh.sh
One of the is root

(5)给定一个用户,判断其UID与GID是否一样,如果一样,就显示此用户为“good guy”;否则,就显示此用户为“bad guy”

#!/bin/bash
USERNAME=user1
USERID=`id -u $USERNAME`
GROUPID=`id -g $USERNAME `
if [ $USERID-eq $GROUPID]
then
echo "good guy" else
echo "bad guy"
fi

 三、测试脚本                                                              

测试脚本是否有语法错误

bash -n file.sh

单步执行脚本

bash -x file.sh

四、定义退出状态码                                                       

exit:退出脚本

exit #

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

  

《鸟哥的Linux私房菜》学习笔记(9)——条件判断的更多相关文章

  1. 鸟哥的linux私房菜学习笔记 __ 命令与文件的搜寻

    连续输入两次[tab]按键就能够知道使用者有多少命令可以下达.那你知不知道这些命令的完整档名放在哪里?举例来说,ls 这个常用的命令放在哪里呢? 就透过 which 或 type 来找寻吧! 范例一: ...

  2. 鸟哥的Linux私房菜学习笔记——文件权限与目录配置

    Linux的文件权限和目录配置 在linux中的每个用户必需属于一个组,不能独立于组外.在linux中每个文件有所有者.所在组.其它组的概念. (1)所有者 一般为文件的创建者,谁创建了该文件,就是天 ...

  3. 鸟哥的Linux私房菜学习笔记(1)

    2014/10/29 1.档案的权限管理分为三个部分: 拥有者.群组.其他 2.ls -al 命令可以看到档案的详细信息 3.档案的属性中由十个部分构成 第一个部分是档案类型 -代表档案.d代表文件夹 ...

  4. 【鸟哥的Linux私房菜】笔记1

    Linux是什么 从操作系统与cpu架构关系到linux  Richard Mathew Stallman GPL 关于GNU计划 Linux的发展 Linux的核心版本 Linux的特色 Linux ...

  5. 鸟哥的linux私房菜学习-(一)优缺点分析以及主机规划与磁盘分区

    一.linux的优缺点 那干嘛要使用Linux做为我们的主机系统呢?这是因为Linux有底下这些优点: 稳定的系统:Linux本来就是基于Unix概念而发展出来的操作系统,因此,Linux具有与Uni ...

  6. 【鸟哥的Linux私房菜】笔记2

    Linux的应用 学习资源整理 安装记录 >< 1.Linux的应用: 网络服务器 数据库 学术机构的高效运算任务 嵌入式系统 ... 2.挂载与磁盘分区 学习资源整理 学习 1.书上的网 ...

  7. 【鸟哥的Linux私房菜】笔记3

    正确地开机 最好不要使用root账号登陆!GNOME图形界面 View items as a list X WindowShell 文本交互界面bash是Shell的名称,Linux的默认壳程序就是b ...

  8. 《鸟哥的Linux私房菜》笔记——02. 关于Linux

    Unix 历史 1969年以前:伟大的梦想--Bell, MIT 与 GE 的「Multics」系统 1969年:Ken Thompson 的小型 file server system 1973年:U ...

  9. 《鸟哥的Linux私房菜》笔记——03. 磁盘分区

    Everything is a file. 常见硬件对应于 Linux 下的文件(/dev目录下) 装置 装置在Linux内的档名 SCSI/SATA/U盘硬盘机 /dev/sd[a-p] U盘 /d ...

  10. 鸟哥的linux私房菜学习

    cat /etc/shells 系统拥有的shellcat /etc/passwd 记录用户使用的shell按两次 tab 键可显示所有可执行的指令alias 查看所有命令的别名alias lm='l ...

随机推荐

  1. 《C#高效编程》读书笔记11-理解短小方法的优势

    我们最好尽可能的编写最清晰的代码,将优化交给JIT编译器完成.一个常见的错误优化是,将大量逻辑放在一个函数中,以期减少额外的方法调用开销.这种将函数逻辑直接写在循环内部的常见优化做法却会降低.NET应 ...

  2. Aspx 验证码_各种封装

    验证码 namespace CZBK.TestProject.Common { public class ValidateCode { public ValidateCode() { } /// &l ...

  3. Java并发包——线程同步和锁

    Java并发包——线程同步和锁 摘要:本文主要学习了Java并发包里有关线程同步的类和锁的一些相关概念. 部分内容来自以下博客: https://www.cnblogs.com/dolphin0520 ...

  4. 关于Arduino项目的构建思想-转自openbook开源杂志

  5. JDBC连接数据库(Servlet+JSP)

    JDBC(Java Database connectivity),是连接数据库的一种方式.后面的框架Mybatis和Hibernate等都封装的是JDBC.在JDBC中常用的API有4个:Driver ...

  6. Javascript Events

    事件通常与函数配合使用,这样就可以通过发生的事件来驱动函数执行. 事件句柄 html4.0的新特性之一是有能力使html事件触发浏览器中的动作action,比如当用户点击某个html元素时启动一段Ja ...

  7. Eucalyptus学习汇总

    Elastic Utility Computing Architecture for Linking Your Programs To Useful Systems (Eucalyptus) 是一种开 ...

  8. 在ActionBar中,即便设置showAsAction="always",items仍然在overflow中显示的问题

    今天很是苦恼,明明设置了android:showAsAction="always",但是所有的items全部都显示在overflow中,然后在官网发现了答案. 如果你为了兼容 An ...

  9. 飞塔NGFW-FortiGate-5.2(BYOL)

    平台: FortiGate 类型: 虚拟机镜像 软件包: basic software FortiGate ips security UTM vpn 反垃圾邮件 网页过滤 服务优惠价: 按服务商许可协 ...

  10. 实战:ADFS3.0单点登录系列-集成Exchange

    本文将介绍如何将Exchange与ADFS集成,从而实现对于Exchange的SSO. 目录: 实战:ADFS3.0单点登录系列-总览 实战:ADFS3.0单点登录系列-前置准备 实战:ADFS3.0 ...