《鸟哥的Linux私房菜》学习笔记(9)——条件判断
一、条件判断表达式
条件测试类型:
- 整数测试
- 字符测试
- 文件测试
条件测试的表达式
[ 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)——条件判断的更多相关文章
- 鸟哥的linux私房菜学习笔记 __ 命令与文件的搜寻
连续输入两次[tab]按键就能够知道使用者有多少命令可以下达.那你知不知道这些命令的完整档名放在哪里?举例来说,ls 这个常用的命令放在哪里呢? 就透过 which 或 type 来找寻吧! 范例一: ...
- 鸟哥的Linux私房菜学习笔记——文件权限与目录配置
Linux的文件权限和目录配置 在linux中的每个用户必需属于一个组,不能独立于组外.在linux中每个文件有所有者.所在组.其它组的概念. (1)所有者 一般为文件的创建者,谁创建了该文件,就是天 ...
- 鸟哥的Linux私房菜学习笔记(1)
2014/10/29 1.档案的权限管理分为三个部分: 拥有者.群组.其他 2.ls -al 命令可以看到档案的详细信息 3.档案的属性中由十个部分构成 第一个部分是档案类型 -代表档案.d代表文件夹 ...
- 【鸟哥的Linux私房菜】笔记1
Linux是什么 从操作系统与cpu架构关系到linux Richard Mathew Stallman GPL 关于GNU计划 Linux的发展 Linux的核心版本 Linux的特色 Linux ...
- 鸟哥的linux私房菜学习-(一)优缺点分析以及主机规划与磁盘分区
一.linux的优缺点 那干嘛要使用Linux做为我们的主机系统呢?这是因为Linux有底下这些优点: 稳定的系统:Linux本来就是基于Unix概念而发展出来的操作系统,因此,Linux具有与Uni ...
- 【鸟哥的Linux私房菜】笔记2
Linux的应用 学习资源整理 安装记录 >< 1.Linux的应用: 网络服务器 数据库 学术机构的高效运算任务 嵌入式系统 ... 2.挂载与磁盘分区 学习资源整理 学习 1.书上的网 ...
- 【鸟哥的Linux私房菜】笔记3
正确地开机 最好不要使用root账号登陆!GNOME图形界面 View items as a list X WindowShell 文本交互界面bash是Shell的名称,Linux的默认壳程序就是b ...
- 《鸟哥的Linux私房菜》笔记——02. 关于Linux
Unix 历史 1969年以前:伟大的梦想--Bell, MIT 与 GE 的「Multics」系统 1969年:Ken Thompson 的小型 file server system 1973年:U ...
- 《鸟哥的Linux私房菜》笔记——03. 磁盘分区
Everything is a file. 常见硬件对应于 Linux 下的文件(/dev目录下) 装置 装置在Linux内的档名 SCSI/SATA/U盘硬盘机 /dev/sd[a-p] U盘 /d ...
- 鸟哥的linux私房菜学习
cat /etc/shells 系统拥有的shellcat /etc/passwd 记录用户使用的shell按两次 tab 键可显示所有可执行的指令alias 查看所有命令的别名alias lm='l ...
随机推荐
- js加密,三种编码方式
·escape(69个):*/@+-._0-9a-zA-Z ·encodeURI(82个):!#$&’()*+,/:;=?@-._~0-9a-zA-Z ·encodeURI ...
- 17.NET Core WebApi跨域问题
官方说明 CORS means Cross-Origin Resource Sharing. Refer What is "Same Origin" Part Detailed P ...
- 【mysql】mysql 配置
安装完mysql后, 要及得配置一下 /etc/mysql/my.cnf 配置字符编码为utf8 [client] default-character-set = utf8 [mysqld] defa ...
- php编码转换相关
iconv (PHP 4 >= 4.0.5, PHP 5, PHP 7) iconv — 字符串按要求的字符编码来转换 string iconv ( string $in_charset , s ...
- Eucalyptus(v4.0)系统需求
1.计算需求 Physical Machines: All Eucalyptus components must be installed on physical machines, not virt ...
- Java笔记--动态代理
Java动态代理 1.概念 代理: 有时我们并不想直接访问对象A,或者不能直接访问对象A.而是通过访问一个中间对象B,让中间对象B去访问A.这种方式就称为代理. 这里的对象A所属的类就为委托类,或者被 ...
- mybatis-映射器的CRUD
设计步骤:model.mapper.dao.service.junit单元测试.log4j日志 项目和之前的一样在此只是创建了test和修改了mapper 1.修改映射 1.1修改接口 package ...
- LeetCode Nim Game (简单nim)
题意: 有一堆石子,里面有n个石头,每次可以从中取出1~3个,两人轮流取,最后一个石子被谁取走即为赢家.你先取,问最后谁赢? 思路: n%4>0则先手赢,因为每次总是可以给对方留4个石子的倍数, ...
- java Vamei快速教程11 对象引用
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我们之前一直在使用“对象”这个概念,但没有探讨对象在内存中的具体存储方式.这方面的 ...
- linux 命令——30 chown (转)
chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID:组可以是组名或者组ID:文件是以空格分开的要改变权限的文件列表,支持通配符.系统管理员经常使用chown命令,在将文件拷贝 ...