《鸟哥的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 ...
随机推荐
- css盒子模型 css3盒子相关样式
1.内边距(内边距在content外,边框内) 内边距属性: padding 设置所有边距 padding-bottom 底边距 padding-left ...
- 粗看ES6之变量
标签: javascript var定义变量面临的问题 可以重复定义 无法限制变量不可修改 无块级作用域 ES6变量定义升级 新增let定义变量 新增const定义常量 let特性 有块级作用域 不可 ...
- 从零开始的全栈工程师——js篇2.17(属性和节点获取)
DOM 一.节点树状图 Document>documentElement>body>tagname 二.常用的节点类型 元素节点(标签) 文本节点(文本节点) 属性节点(标签里的属性 ...
- Python接入支付宝进行PC端支付
1. 支付宝开放平台登录,使用支付宝账号登录 https://open.alipay.com/platform/home.htm 2.选择沙箱模式 [支付宝提供了测试环境] https://docs ...
- Miner3D Professional专业版
——高级的可视化数据分析为专业人士量身打造 Miner3D Professional 专业版可以帮助工程师,研究人员,分析师,管理人员,知识工作者,以分析师和信息专家,在较短的时间内作出更好的判断.探 ...
- ionic 2 起航 控件的使用 客户列表场景(三)
我们来看看客户列表的搜索控件是怎么工作的吧. 1.打开customer.html <ion-content> <ion-searchbar [(ngModel)]="sea ...
- Windows 10 下使用Git
事实上,比在Linux下要难很多.不仅仅是因为Linux下CMD功能较弱,还有就是国内的网络环境,至少,我这Github Windows安装时,总是会下载无法完成 Github Desktop 虽然, ...
- uLua学习之读取外部Lua脚本(四)
前言 上节说到了Lua脚本与unity3d中C#脚本的数据交互,但是我感觉上节中的数理方式不太好,因为我们是把Lua脚本以字符串形式粘贴到C#脚本中的,如果读取配置数据都这样做的话,那就太可怕了.想想 ...
- 基于jeesit下的工作流开发步骤
首先jeesit是开源的OA系统,采用的框架是springMVC和mybatis,采用shiro安全验证. 1.新建流程所属表: 在数据库新建所需工作流的表之后,登录jeesit系统,在“代码生成”- ...
- thinkphp分页+条件查询
最近项目上面有一个带条件查询的分页列表,一开始form用的post,点击第二页就没有跳转成功,原因是分页是get请求,post数据链接到其他页面就会被清除. 解决办法: 1.form表单method= ...