Shell编程自动化之数学运算与条件测试

简介: 本文主要介绍了Shell编程自动化之数学运算与条件测试,并结合实例测试。

一、Shell数学运算

1.Shell常见的算术运算符号

序号 算术运算符号 意义
1 +、-、*、/、% 加、减、乘、除、取余
2 ** 幂运算
3 ++、-- 自增或自减
4 &&、!、(两条竖线) 与、或、非
5 ==、!= 相等、不相等,==也可写成=
6 =、+=、-=、*=、/=、%= 赋值运算符,a+=1相等于a=a+1

2.Shell常用算术运算命令

序号 算术运算命令 意义
1 (())、let、$[] 用于整数运算
2 expr 可用于整数运算,还有其他功能
3 awk、bc 可用于整数运算,也可用于小数运算

3.实例测试:

2024-01-06_linux_shell_01.png

二、Shell条件测试

1.条件测试常用的语法

序号 条件测试语 意义
1 test <测试表达式> 这是利用test命令进行条件测试表达式的方法,test命令和“<测试表达式>”之间至少有一个空格。
2 [ <测试表达式> ] [ ]的边界和内容之间至少有一个空格。

2.test条件测试

常用文件类型、文件权限、文件比较、整数比较、字符串判断和逻辑判断。

序号 参数 意义
1 -e 判断文件(普通文件或目录文件)是否存在
2 -f 判断普通文件是否存在
3 -d 判断目录文件是否存在
4 -r 判断文件是否有读权限
5 -w 判断文件是否有写权限
6 -x 判断文件是否有执行权限
7 -nt test file1 -nt file2,判断file1是否比file2新
8 -ot test file1 -ot file2,判断file1是否比file2旧
9 -ef test file1 -ef file2,判断file1和file2是否同一文件
10 -eq 判断两个整数是否相等
11 -ne 判断两个整数是否不相等
12 -gt test n1 -gt n2,判断整数1是否大于整数2
13 -lt test n1 -lt n2,判断整数1是否小于整数2
14 -ge test n1 -ge n2,判断整数1是否大于等于整数2
15 -le test n1 -le n2,判断整数1是否小于等于整数2
16 -z 判断字符串是否为0?若字符串为空字符串,则为真,否则反
17 -n 判断字符串是否为非0?若字符串为非空字符串,则为真,否则反
18 == 判断两个字符串是否相等
19 != 判断两个字符串是否不相等
20 &&或-a 逻辑与,两端都为真,则为真
21 (两条竖线)或-o 逻辑或,两端其中一端为真,则为真
22 逻辑非,取反

2024-01-06_linux_shell_02.png

3.中括号[ ]的条件测试

在脚本中经常进行条件测试,用的最多的是中括号[ ],功能与test一样,中括号与内容两边必须有空格,在条件测试中使用变量必须添加双引号,例如:[ -n "$str" ]

2024-01-06_linux_shell_03.png


相关文章
|
1月前
|
存储 关系型数据库 测试技术
玩转n8n测试自动化:核心节点详解与测试实战指南
n8n中节点是自动化测试的核心,涵盖触发器、数据操作、逻辑控制和工具节点。通过组合节点,测试工程师可构建高效、智能的测试流程,提升测试自动化能力。
|
26天前
|
机器学习/深度学习 人工智能 测试技术
EdgeMark:嵌入式人工智能工具的自动化与基准测试系统——论文阅读
EdgeMark是一个面向嵌入式AI的自动化部署与基准测试系统,支持TensorFlow Lite Micro、Edge Impulse等主流工具,通过模块化架构实现模型生成、优化、转换与部署全流程自动化,并提供跨平台性能对比,助力开发者在资源受限设备上高效选择与部署AI模型。
225 9
EdgeMark:嵌入式人工智能工具的自动化与基准测试系统——论文阅读
|
3月前
|
XML jenkins 机器人
JMeter+Ant+Jenkins实现接口自动化测试持续集成
本文介绍了如何使用Ant生成JMeter接口测试报告,并集成到Jenkins中实现自动化测试。内容涵盖Ant与JMeter环境配置、build.xml文件设置、测试执行及报告生成,同时包括Jenkins插件安装、项目配置和钉钉消息通知的集成,帮助实现持续测试与结果可视化。
515 0
|
21天前
|
自然语言处理 前端开发 测试技术
使用 Playwright MCP 实现 UI 自动化测试
本文介绍如何结合Playwright与MCP协议实现智能化UI自动化测试。通过自然语言指令控制浏览器,降低技术门槛,提升效率,并涵盖环境搭建、核心功能、实战案例及最佳实践,展现对话式自动化的未来趋势。
|
3月前
|
人工智能 前端开发 测试技术
如何让AI帮你做前端自动化测试?我们这样落地了
本文介绍了一个基于AI的UI自动化测试框架在专有云质量保障中的工程化实践。
1555 21
如何让AI帮你做前端自动化测试?我们这样落地了
|
3月前
|
Web App开发 开发框架 .NET
Playwright 自动化测试系列(6)| 第三阶段:测试框架集成​指南:参数化测试 + 多浏览器并行执行
Pytest 与 Playwright 集成可提升自动化测试效率,支持参数化测试、多浏览器并行执行及统一报告生成。通过数据驱动、Fixture 管理和并行优化,显著增强测试覆盖率与执行速度,适用于复杂 Web 应用测试场景。
|
2月前
|
人工智能 IDE 测试技术
Browser-Use在UI自动化测试中的应用
Browser-Use是一款浏览器自动化工具,具备视觉与HTML解析、多标签管理、操作记录与复现、自定义操作、自我纠正及并行执行等功能,助力AI智能体高效完成网页任务。
222 0
|
3月前
|
测试技术 API C++
Playwright 自动化测试系列(7)| 第三阶段:测试框架集成​​Page Object 模式
本课程详解Playwright测试框架中的Page Object模式,通过电商登录-下单实战演示PO架构设计与高级技巧,结合Pytest实现多用户测试。重点解析PO模式提升代码复用性、降低维护成本的核心价值,并提供常见问题解决方案,助力构建高可维护性的自动化测试体系。
|
5月前
|
人工智能 自然语言处理 测试技术
UGMathBench:评估语言模型数学推理能力的动态基准测试数据集
近年来,人工智能蓬勃发展,自然语言模型(LLM)进展显著。语言模型被广泛应用于自动翻译、智能客服、甚至医疗、金融、天气等领域。而研究者们仍在不断努力,致力于提高语言模型的规模和性能。随着语言模型的蓬勃发展,评估一个语言模型的性能变得越来越重要。其中一个重要的评估指标,就是衡量语言模型的推理能力和解决数学问题的能力。
284 38
|
4月前
|
JavaScript 测试技术 Python
UI自动化测试中的元素等待机制解析
在UI自动化测试中,元素定位失败常因页面存在iframe或缺乏合理等待机制。本文解析三种等待策略及其应用场景:显式等待可精确控制单个元素等待条件,支持自定义轮询;隐式等待全局生效,适合简单页面加载;强制等待仅用于临时调试,正式脚本慎用。通过对比三者执行精度、资源消耗及适用场景,帮助选择最优策略,提升测试效率与稳定性。