Linux之shell条件测试

华子目录

  • 用途
  • 基本语法
    • 格式
    • 示例
  • 文件测试
    • 参数
    • 示例
  • 整数测试
    • 作用
    • 操作符
    • 示例
      • =~:检查左侧内容是否匹配右侧的正则表达式
  • 案例分析
  • 逻辑操作符
    • 符号
    • 示例
  • 命令分隔符
    • &>:不管成功与否,都将信息写进黑洞中

用途

  • 为了能够正确处理shell程序运行过程中遇到的各种情况, Linux shell提供了一组测试运算符
  • 通过这些运算符shell程序能够判断某种或者几个条件是否成立
  • 条件测试各种流程控制语句,例如判断语句和循环语句中发挥了重要的作用,所以了解和掌握这些条件测试是非常重要的

基本语法

格式

格式1:test -参数 条件表达式  #常用作文件测试
格式2:[ 条件表达式 ]  #注意:[]的左右要有空格,常用来文件测试
格式3:[[ 条件表达式 ]]  #注意:[]的左右要有空格,文件测试,整数判断都可以
格式4:((条件表达式))  #不支持文件测试,不支持小数测试,支持整数判断
  • test单独使用,判断条件为真,echo $?返回0,假返回1
  • test与[ ]等价
  • [[ ]] 是扩展命令,可以使用通配符(?*)等进行模式匹配,&& || > < 等操作符可以直接应用于双中括号中,但不能用于单中括号中
  • (()) 一般用于if语句里,两端不需要有空格,测试对象为整数

示例

# test 单独使用,必须配合状态码测试,0表示成立,1为不成立
[root@server ~]# test -f /etc/passwd
[root@server ~]# echo $?
0
[root@server ~]# test -f /a1.txt
[root@server ~]# echo $?
1
# test配置自编逻辑表示(成立为1,不成立为0)
[root@server ~]# test -f /etc/hosts && echo 1 || echo 0
1
[root@server ~]# test -f /etc/a1.txt && echo 1 || echo 0
0
#[]等价于test
[root@server ~]# [ -f /etc/passwd ]
[root@server ~]# echo $?
0

[root@server ~]# [ -f /etc/a1.txt ]
[root@server ~]# echo $?
1



[root@server ~]# [ -f /etc/passwd ] && echo 1 || echo 0
1
[root@server ~]# [ -f /etc/a1.txt ] && echo 1 || echo 0
0
[root@server ~]# [[ 3>2 || 1>2 ]]
-bash: 条件命令中有未预期的符号 284
-bash: “3>”附近有语法错误
[root@server ~]# [[ 3 > 2 || 1 > 2 ]]
[root@server ~]# echo $?
0


[root@server ~]# [[ 3 > 2 || 1 > 2  ]]  && echo yes || echo no
yes
[root@server ~]# [[ 3 > 2 && 1 > 2  ]]  && echo yes || echo no
no
[root@server ~]# ((3>5))  && echo  1  || echo 0
0
[root@server ~]# ((3<5))  && echo  1  || echo 0
1
[root@server ~]# ((-f /etc/passwd))  && echo  1  || echo 0  # 不支持文件测试
-bash: ((: -f /etc/passwd:除以 0 (错误符号是 "etc/passwd")
0
[root@server ~]# ((9.5!=0))  && echo  1  || echo 0  # 不支持小数测试
-bash: ((: 9.5!=0:语法错误: 无效的算术运算符 (错误符号是 ".5!=0")
0

文件测试

参数

参数作用
-b 文件名检测文件是否是块设备文件,是返回true
-c 文件名是否是字符设备文件
-d 文件名是否是目录
-f 文件名是否是文本文件
-S 文件名是否是socket文件
-P 文件名是否为管道符文件
-L 文件名是否为链接文件
-u 文件名是否有suid的权限
-s 文件名是否为空文件(文件大小是否大于0),不为空返回true
-e 文件名检测文件(包括目录)是否存在,如果是,则返回true
-r 文件名检测文件是否可读,如果是,则返回true
-w 文件名检测文件是否可写,如果是,则返回true
-x 文件名检测文件是否可执行,如果是,则返回true
f1 -nt f2文件f1比文件f2新则为真(根据文件修改时间计算)
f1 -ot f2文件f1比文件f2旧则为真(根据文件修改时间计算)

示例

[root@server ~]# [ -d /root ] && echo yes || echo no  
yes
[root@server ~]# [ -b /nvme0n1 ] && echo yes || echo no  
no
[root@server ~]# [ -b /dev/nvme0n1 ] && echo yes || echo no  
yes
[root@server ~]# [ -L  /dev/cdrom ] && echo yes || echo no  
yes
[root@server ~]# test  -e  /etc/file1  && echo  yes || echo no
no
[root@server ~]# touch  /etc/file1
[root@server ~]# test  -e  /etc/file1  && echo  yes || echo no
yes
[root@server ~]# [[ -r  /etc/sr0  ]]  && echo  1  || echo 0
0
[root@server ~]# [[ -r  /dev/sr0  ]]  && echo  1  || echo 0
1
[root@server ~]# (( -r  /dev/sr0 ))  && echo  1  || echo 0    # (())不支持文件测试
-bash: ((: -r  /dev/sr0 :除以 0 (错误符号是 "dev/sr0 ")
0
  • 编写脚本,测试在根目录下文件是否存在,文件名从键盘输入,若不存在则创建
[root@server ~]# vim test1.sh
#!/bin/bash

read  -p "请输入文件名称: "  filename

if  test -e /$filename
then
        echo  "$filename exists and it is a normal file"
else    
        echo  "$filename doesn't exit!!"
        echo  "create  file  $filename automatically"
        touch  /$filename
fi      



[root@server ~]# bash test1.sh
请输入文件名称:hhh
hhh doesn't exit!!
create file hhh automatically
[root@server ~]# ls /
afs  boot  etc  home  lib64  mnt  proc  run   srv  tmp  var
bin  dev   hhh  lib   media  opt  root  sbin  sys  usr
  • 使用位置变量处理
[root@server ~]# vim test1.sh
filename=$1   # 接收位置变量

if  test -e /$filename
then
        echo  "$filename exists and it is a normal file"
else
        echo  "$filename doesn't exit!!"
        echo  "create  file  $filename automatically"
        touch  /$filename
fi



[root@server ~]# bash test1.sh hhh    # 注意:执行时文件名作为位置变量参数
hhh exists and it is a normal file
[root@server ~]# bash test1.sh a2.txt
a2.txt doesn't exit!!
create file a2.txt automatically
[root@server ~]# ls /
a2.txt  bin   dev  hhh   lib    media  opt   root  sbin  sys  usr
afs     boot  etc  home  lib64  mnt    proc  run   srv   tmp  var
# 注意:使用find检测文件注意状态码

整数测试

作用

  • 用于比较两个数值的大小关系,操作的对象是数值

操作符

在这里插入图片描述

示例

[root@server ~]# [ 5 -gt 3 ]  &&  echo  1  || echo 0
1
[root@server ~]# [ 5 >  3 ]  &&  echo  1  || echo 0
1
[root@server ~]# test  2  -lt 1  && echo 1  || echo 0  
0
[root@server ~]# ((5>3))  && echo  1  || echo 0
1

=~:检查左侧内容是否匹配右侧的正则表达式

[root@server ~]# n1=123
[root@server ~]# [[ $n1 =~ ^[0-9]+$ ]] && echo 1 || echo 0
1

[root@server ~]# n2="china"
[root@server ~]# [[ $n2 =~ ^[0-9]+$ ]] && echo 1 || echo 0
0

[root@server ~]# n3=123abc
[root@server ~]# [[ $n3 =~ ^[0-9]+$ ]] && echo 1 || echo 0
0

案例分析

  • 编写表达式,测试系统用户少于50个则输出相关信息
[root@server ~]# cat /etc/passwd | wc -l
37

[root@server ~]# [ $(cat  /etc/passwd | wc -l) -lt 50  ] && echo "用户数小于50"  || echo "用户数大于50"
用户数小于50
  • 判断当前已登录的账户数,超过5个则输出提示信息
[root@server ~]# who
root     pts/1        2024-03-15 15:34 (192.168.80.1)
[root@server ~]# who | cut -d " " -f 1
root
[root@server ~]# who | cut -d " " -f1
root
[root@server ~]# who | cut -d " " -f 1 | sort -u
root
[root@server ~]# who | cut -d " " -f 1 | sort -u | wc -l
1
[root@server ~]# [ $(who | cut -d " " -f 1 | sort -u | wc -l) -gt 5] && echo "账户过多" || echo "实际账户数:$(who | cut -d " " -f 1 | sort -u | wc -l)"
-bash: [: 缺少 `]'
实际账户数:1

[root@server ~]# num=$(who | cut -d " " -f 1 | sort -u | wc -l)

[root@server ~]# [ $num -gt 5 ] && echo "账户过多" || echo "实际账户数:$num"
实际账户数:1



# who :查看账户信息
# cut -d  " "  -f1  : 以空格作为列间隔符,截取第1列
# sort -u :去重后排序
# wc :-l :统计行数
  • 如果/var/log/messages 文件行数大于50行,则显示提示信息
[root@server ~]# (($(cat  /var/log/messages | wc -l)>50))  &&  echo  "好大一个文件"  || echo  "还能接受"
好大一个文件
  • 编写一个脚本mkfs.sh,功能:显示root账户下的文件信息,之后建立一个aa目录,在aa目录中新建一个文件bb.txt,并修改为可执行的权限
[root@server ~]# vim  mkfs.sh
#!/bin/bash
ls  /root
mkdir  /root/aa
touch  /root/aa/bb.txt
chmod a+x /root/aa/bb.txt    #(a表示all,所有人)
[root@server ~]# bash mkfs.sh 


  • 编写脚本mkd.sh,从键盘输入一个目录名,判断是否存在,不存在则创建
[root@server ~]# vim  mkd.sh
#!/bin/bash
cd  /
ls
read -p "请输入一个目录名称: " dir
[ -d $dir ] && ls -ld $dir  || ( echo  "目录不存在,开始新建目录." ;  mkdir  $dir ;  ls  -ld  $dir)


[root@server ~]# bash  mkd.sh
  • 编写脚本sum1.sh,从键盘读入2个整数存储到x,y中,计算和值后输出
[root@server ~]# vim sum1.sh
#!/bin/bash
read -p "请输入x的值: " x
read -p "请输入y的值: " y
if  [ -n $x -a -n $y ]   # 判断是否为空
then
        if [[ $x =~  ^[0-9]+$ ]]  &&  [[ $y =~ ^[0-9]+$ ]]  # 判断是否为数字
        then
                sum=$[x+y]
                echo "$x+$y=$sum"
        else
                echo  "请输入数字."
        fi
else
        echo "请输入有效数字."
fi
  • 编写脚本user1.sh,显示所有账户,选择一个账户输入,若id为0则表示管理员,否则表示其他账户
[root@server ~]# vim  user1.sh
#!/bin/bash
cat /etc/passwd  |  cut -d ":" -f1 | sort -u
read -p "请输入账户名:" us
[ $(id -u $us)  -eq 0 ] && echo  "此账户为管理员" || echo "此账户为其他账户"



[root@server ~]# bash user1.sh 
  • 编写脚本line1.sh ,统计/etc/sos/sos.conf文件中的空白行(^$),若有空白行则显示行数,否则输出提示信息
[root@server ~]# vim  line1.sh
#!/bin/bash
num=$( grep ^$ /etc/sos/sos.conf | wc -l )
if (($num>0))  #  [ $numn -gt 0  ]
then
        echo "/etc/sos/sos.conf 包含空白行,行数为: $num行"
        grep  -n  ^$  /etc/sos/sos.conf
else
        echo "/etc/sos/sos.conf 文件无空白行"
fi
# 修改为任意文件的测试
[root@server ~]# vim  line1.sh
#!/bin/bash
read -p "请输入需要统计的文件名: "  filename
num=$( grep ^$  $filename  | wc -l )
if (($num>0))  #  [ $numn -gt 0  ]
then
        echo "$filename  包含空白行,行数为: $num行"
        grep  -n  ^$  $filename
else
        echo "$filename  文件无空白行"
fi

逻辑操作符

符号

在这里插入图片描述

示例

[root@server ~]# [ -f /etc/passwd -a -f /etc/services ] && echo 1 || echo 0
1
[root@server ~]# [ -f /etc/hosts -o -d /etc/services ] && echo  1 || echo 0
1
[root@server ~]# ((5<10 && 5>2))  && echo y || echo n
y
[root@server ~]# ((2<5<10))  && echo y || echo n
y
[root@server ~]# ((2<5<1))  && echo y || echo n
n
[root@server ~]# ((6<5<10))  && echo y || echo n
y
[root@server ~]# ((2<5<-1))  && echo y || echo n
n

命令分隔符

cmd1;cmd2     以独立的进程依次执行cmd1和cmd2
(cmd1;cmd2)   在同一进程中依次执行cmd1和cmd2
cmd1&cmd2     cmd1和cmd2同时执行,分属于不同的进程
cmd1&&cmd2    当cmd1为真时,则执行cmd2
cmd1||cmd2    当cmd1不为真时,则执行cmd2
cmd&          后台执行

&>:不管成功与否,都将信息写进黑洞中

# 若账户fox10不存在,则添加账户
[root@server ~]# id fox10  &>  /dev/null  &&  echo  "fox10已存在"  ||  useradd  fox10
# &>  /dev/null 表示将左侧命令执行的正确和错误输出到“黑洞”即不显示到屏幕(不管成功与否,都将信息写进黑洞中)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/461817.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

django开发流式格式后的在nginx的部署的记录

关键记录. django上传代码要导出配置 pip freeze > requirements.txt 这个很关键。后面部署直接读取的 关键记录. django上传代码要导出配置 pip freeze > requirements.txt 这个很关键。后面部署直接读取的 关键记录. django上传代码要导出配置 pip freeze > require…

Python 基础语法:基本数据类型(字典)

为什么这个基本的数据类型被称作字典呢&#xff1f;这个是因为字典这种基本数据类型的一些行为和我们日常的查字典过程非常相似。 通过汉语字典查找汉字&#xff0c;首先需要确定这个汉字的首字母&#xff0c;然后再通过这个首字母找到我们所想要的汉字。这个过程其实就代表了…

Unity的AssetBundle资源运行内存管理的再次深入思考

大家好&#xff0c;我是阿赵。   这篇文章我想写了很久&#xff0c;是关于Unity项目使用AssetBundle加载资源时的内存管理的。这篇文章不会分享代码&#xff0c;只是分享思路&#xff0c;思路不一定正确&#xff0c;欢迎讨论。   对于Unity引擎的资源内存管理&#xff0c;我…

调皮的String及多种玩法(下部)

&#x1f468;‍&#x1f4bb;作者简介&#xff1a;&#x1f468;&#x1f3fb;‍&#x1f393;告别&#xff0c;今天 &#x1f4d4;高质量专栏 &#xff1a;☕java趣味之旅 欢迎&#x1f64f;点赞&#x1f5e3;️评论&#x1f4e5;收藏&#x1f493;关注 &#x1f496;衷心的希…

0101插入排序-算法基础-算法导论第三版

文章目录 一 插入排序二 循环不变式与插入排序的正确性三 伪代码中的一些约定四 Java代码实现插入排序结语 一 插入排序 输入&#xff1a; n n n个数订单一个序列 ( a 1 , a 2 , ⋯ , a n ) (a_1,a_2,\cdots,a_n) (a1​,a2​,⋯,an​). **输出&#xff1a;**输入序列的一个排…

【how2j练习题】HTML部分综合练习

练习题 1 <html><h1>英雄联盟 &#xff08;电子竞技类游戏&#xff09;</h1> <p> <strong>《英雄联盟》</strong>&#xff08;简称lol&#xff09;是由美国<i>Riot Games</i>开发&#xff0c;中国大陆地区由腾讯游戏运营的网络…

openGauss学习笔记-244 openGauss性能调优-SQL调优-典型SQL调优点-统计信息调优

文章目录 openGauss学习笔记-244 openGauss性能调优-SQL调优-典型SQL调优点-统计信息调优244.1 统计信息调优244.1.1 统计信息调优介绍244.1.2 实例分析&#xff1a;未收集统计信息导致查询性能差 openGauss学习笔记-244 openGauss性能调优-SQL调优-典型SQL调优点-统计信息调优…

4.10.CVAT——3D对象标注

文章目录 1. 创建任务2. 3D 任务工作区3.标准 3D 模式 Standard 3D mode4. 用长方体进行注释4.1. 用shapes进行注释4.2. 使用长方体进行跟踪Tracking 使用 3D 注释工具来标记 3D 对象和场景&#xff0c;例如车辆、建筑物、景观等。 1. 创建任务 要创建 3D 任务&#xff0c;您必…

快速从0-1完成聊天室开发——环信ChatroomUIKit功能详解

聊天室是当下泛娱乐社交应用中最经典的玩法&#xff0c;通过调用环信的 IM SDK 接口&#xff0c;可以快速创建聊天室。如果想根据自己业务需求对聊天室应用的 UI界面、弹幕消息、礼物打赏系统等进行自定义设计&#xff0c;最高效的方式则是使用环信的 ChatroomUIKit 。 文档地址…

面试题手撕篇

参考博客 开始之前&#xff0c;理解递归 手写 浅拷贝 function shallow(target){if(target instanceof Array){return [...resObj]}else{return Object.assign({},target);} }手写深拷贝 const _sampleDeepClone target > {// 补全代码return JSON.parse(JSON.stringify…

mybatis源码阅读系列(一)

源码下载 mybatis 初识mybatis MyBatis 是一个优秀的持久层框架&#xff0c;它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射&#xff0c;将接口和 Java 的…

UE4_调试工具_绘制调试球体

学习笔记&#xff0c;仅供参考&#xff01; 效果&#xff1a; 步骤&#xff1a; 睁开眼睛就是该变量在此蓝图的实例上可公开编辑。 勾选效果&#xff1a;

【小白刷leetcode】第15题

【小白刷leetcode】第15题 动手刷leetcode&#xff0c;正在准备蓝桥&#xff0c;但是本人算法能力一直是硬伤。。。所以做得一直很痛苦。但是不熟练的事情像练吉他一样&#xff0c;就需要慢速&#xff0c;多练。 题目描述 看这个题目&#xff0c;说实在看的不是很懂。索性我们直…

GUROBI建模之非线性约束的处理

官方文档 目录 官方文档&#xff1a;GRBModel.AddGenConstrXxx() - Gurobi Optimization 数学规划的约束类型 基本约束(fundamental constraints)&#xff1a; 通用约束(general constraints): 1. GUROBI求解器有针对这类约束的函数&#xff0c;直接调用这类函数即可 2.…

Python-GIS分析之地理数据空间聚类

地理空间数据聚类是空间分析和地理信息系统(GIS)领域的一项关键技术。这种方法对于理解地理数据固有的空间模式和结构、促进城市规划、环境管理、交通和公共卫生等各个领域的决策过程至关重要。本文探讨了地理空间数据聚类的概念、方法、应用、挑战和未来方向。 当模式出现…

音频切割如何操作?剪辑音乐入门教程

随着数字音乐时代的来临&#xff0c;音频编辑和音乐剪辑成为了越来越多人的必备技能。无论是想要制作个人音乐作品&#xff0c;还是想要为视频添加背景音乐&#xff0c;了解如何切割和剪辑音频都是非常重要的。本文将为你提供一份音频切割和音乐剪辑的入门教程&#xff0c;帮助…

13-操作符(初识)

课前小技巧&#xff1a;VS中&#xff0c;想要复制哪一行&#xff0c;直接把鼠标放在哪一行&#xff0c;CtrlC即可&#xff0c;CtrlV直接自动复制到下一行 C语言非常灵活&#xff1a;C语言提供了非常丰富的操作符&#xff0c;使用起来比较灵活 13-1 算术操作符 - * / % 这…

WXML 模板语法

数据绑定 1. 数据绑定的基本原则 ① 在 data 中定义数据 在页面对应的 .js 文件中&#xff0c;把数据定义到 data 对象中即可 ② 在 WXML 中使用数据 2. Mustache 语法的格式 把 data 中的数据绑定到页面中渲染&#xff0c;使用 Mustache 语法&#xff08;双大括号&#x…

快速了解JavaScript

1.1 javaScript 历史 创始人 布兰登 艾奇 生于1961年 在1995设计LiveScript后改名为JavaScript 1.2 javaScript 是什么类型的语言 JavaScript是一种在客户端运行的脚本语言&#xff08;不需要编译&#xff0c;由js引擎逐行解释执行&#xff09; 1.3 JavaScript可以做什么 …

ts版本微信小程序在wxml保存文件不刷新页面的解决办法

将project.config.json中的skylineRenderEnable改为false "skylineRenderEnable": false
最新文章