linux|shell编程|shell脚本的一些高级技巧(shell脚本内的括号,中括号,花括号,逻辑判断,脚本优雅退出等等)

简介: linux|shell编程|shell脚本的一些高级技巧(shell脚本内的括号,中括号,花括号,逻辑判断,脚本优雅退出等等)

前言:

shell脚本说容易其实也是容易的,说难,那真的是可以难到让人挠头的地步,因为逻辑判断,自定义变量,环境变量,系统内置函数,脚本结构设计这些糅合到一起后,脚本可能会变的非常复杂了。

那么,本文主要就shell脚本内使用系统函数(dirname,basename,exit),逻辑判断符号,gt,lt,eq,ne,ge,le,n,r,x,w,e,d,f ,z,变量包裹符 ()[] {} [[]] ` 这些内容做一个粗略的介绍

一,

变量的定义

例如,定义一个变量a,该变量的值是10

a=10

错误定义(两头有空格是错误的e):

[root@EULER2 ~]# a =2
-bash: a: command not found
^[[6~[root@EULER2 ~]# a= 2
-bash: 2: command not found

那么,这种定义方式是最简单的,需要注意,变量名称和变量值之间的=号两边不能有空格

OK,结合实际的工作来说,变量肯定不能这么简单了,比如,定义一个变量b,给它赋值某个文本文件的内容(这里用的是反引号)

[root@EULER2 ~]# b=`cat test.sh `
[root@EULER2 ~]# echo $b
#!/bin/bash a=12 b=12 if [ $a -eq $b ]; then echo "bianliang a dengyu bianliang b " else echo "bianliang a budengyu bianliang b " fi

第二种定义方式($符合结合单括号):

[root@EULER2 ~]# b=$(cat test.sh)
[root@EULER2 ~]# echo $b
#!/bin/bash a=12 b=12 if [ $a -eq $b ]; then echo "bianliang a dengyu bianliang b " else echo "bianliang a budengyu bianliang b " fi

那么,这两种方式有何不同?到底用哪种比较合适呢?

效果基本是相同的,只是反引号是一个老的用法,$( ) 是 新 的 用 法 , 无 论 是 在 学 习 还 是 实 际 工 作 中 , 建议还是使用$(),理由如下:

1,

反引号容易和引号混淆

2,

反引号处理特殊字符的时候需要多写一个转义符,例如

[root@EULER2 ~]# echo $HOSTNAME
EULER2
[root@EULER2 ~]# b=`echo $HOSTNAME`
[root@EULER2 ~]# echo $b
EULER2

此时,如果只想输出$HOSTNAME 而不是EULER2,那么,应该使用双层转义符

[root@EULER2 ~]# b=`echo \\$HOSTNAME`
[root@EULER2 ~]# echo $b
$HOSTNAME

单层转义符并没有什么用:

[root@EULER2 ~]# b=`echo \$HOSTNAME`
[root@EULER2 ~]# echo $b
EULER2

而$()只需要一个转义符就可以了,但需要考虑的是反引号书写更为简单。

二,

逻辑判断符

逻辑判断符主要用在脚本的if语句,while循环,for循环,case选择这些语句内,也就是通常是内嵌在这些语句内的。从而控制这些语句的运行方向(例如,是否跳出循环,是否进入下一个条件等等),具体的实施中其实也就是两个变量的值的逻辑判断,判断两者的值是否大于(gt),大于等于(ge),等于(eq),小于(lt),小于等于(le),字符串长度为零(z),字符串长度非零(n)这些逻辑关系。

1,-gt -ge

-gt   判断某个变量是否大于某个值

-ge  判断某个变量是否大于或者等于某个值

那么,/etc/profile这个脚本文件是比较全面的,部分逻辑判断符就以此文件做示例吧

if [ $UID -gt 199 ] && [ "`/usr/bin/id -gn`" = "`/usr/bin/id -un`" ]; then
    umask 002
else
    umask 022
fi

这一段shell代码表示当uid仅大于199的时候,umask的值是002,小于等于199的时候,umask的值是022

2,

-lt -le

-lt 判断某个变量的值是否小于某个数值

-le 判断某个变量的值是否小于等于某个数值

例如下面的脚本:

#!/bin/bash
a=20
if [ $a -lt 15 ];
then
echo "bianliang a shi xiaoyu 15de "
else
echo "bianliang a shi dayu 15de "
fi

很明显,20小于15为假,因此,输出的是else后面的代码

3,

-z和-n和$变量

-z判断字符串的长度是否为零,为0返回真

-n判断字符串的长度是否不为零,不为0返回真

$变量同-n,判断字符串的长度是否不为零,不为0返回真

-z的示例(特别注意,使用了双引号):

#!/bin/bash
a=shiguang
b=""
if [ -z $a ];
then
echo "a zifuchuan wei kong"
else
echo "a zifuchuan you neirong"
fi
if [ -z $b ];
then
echo "b zifuchuan wei kong"
else
echo "b zifuchuan you neirong"
fi
[root@EULER2 ~]# bash test.sh 
a zifuchuan you neirong
b zifuchuan wei kong

-n的示例(特别注意,使用了双引号)

[root@EULER2 ~]# bash test.sh 
a zifuchuan you
b zifuchuan meiyou
#!/bin/bash
a=shiguang
b=""
if [ -n "$a" ];
then
echo "a zifuchuan you"
else
echo "a zifuchuan meiyou"
fi
if [ -n "$b" ];
then
echo "b zifuchuan you"
else
echo "b zifuchuan meiyou"
fi

$变量的示例(尽量使用""双引号包裹,本例没有使用双引号,其实是不规范的):

#!/bin/bash
a="shiguang"
if [ $a ];
then
echo "a bu kong"
else
echo "a kong"
fi
[root@EULER2 ~]# bash test1.sh 
a bu kong

####:注,如果是双中括号,不需要双引号包裹变量,否则需要双引号包裹变量,例如:

#!/bin/bash
a=""
if [[ $a ]];
then
echo "a bu kong"
else
echo "a kong"
fi

输出为:

aest1.sh 
2. a kong

4,

=  ==  -eq

这三个都是等于的判断,但需要注意它们的使用范围,==可以比较判断字符串和整数数字,-eq只可以比较判断整数数字,也就是说-eq的范围会比较窄,=也可以比较判断字符串和整数数字,在算数运算表达式“(( ))”中,单等号是赋值算数运算符,双等号为相等算数运算符,可以这么认为它们的使用范围:== 大于 = 大于 -eq ,另外,在逻辑判断时,一般是使用双中括号的,不使用单中括号

例子如下:

#!/bin/bash
a="shiguang"
b="shiguang"
if [[ $a = $b ]];
then
echo "a dengyu b"
else
echo "a budengyu b"
fi

未完待续!!!

目录
相关文章
|
4月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
479 10
|
4月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
421 2
|
7月前
|
Shell
Shell脚本循环控制:shift、continue、break、exit指令
使用这些命令可以让你的Shell脚本像有生命一样动起来。正确使用它们,你的脚本就能像一场精心编排的舞蹈剧目,既有旋律的起伏,也有节奏的跳跃,最终以一场惊艳的表演结束。每一个动作、每一个转折点,都准确、优雅地完成所需要表达的逻辑。如此,你的脚本不只是冰冷的代码,它透过终端的界面,跳着有节奏的舞蹈,走进观众——使用者的心中。
299 60
|
4月前
|
数据采集 监控 Shell
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
Shell脚本利用curl/wget发起请求,结合文本处理工具构建轻量级爬虫,支持并行加速、定时任务、增量抓取及分布式部署。通过随机UA、异常重试等优化提升稳定性,适用于日志监控、价格追踪等场景。相比Python,具备启动快、资源占用低的优势,适合嵌入式或老旧服务器环境,复杂任务可结合Python实现混合编程。
|
6月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
777 1
|
4月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
499 1
二、Linux文本处理与文件操作核心命令
|
4月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
345 137
|
4月前
|
安全 Ubuntu Unix
一、初识 Linux 与基本命令
玩转Linux命令行,就像探索一座新城市。首先要熟悉它的“地图”,也就是/根目录下/etc(放配置)、/home(住家)这些核心区域。然后掌握几个“生存口令”:用ls看周围,cd去别处,mkdir建新房,cp/mv搬东西,再用cat或tail看文件内容。最后,别忘了随时按Tab键,它能帮你自动补全命令和路径,是提高效率的第一神器。
791 57
|
3月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
613 2
|
4月前
|
缓存 监控 Linux
Linux内存问题排查命令详解
Linux服务器卡顿?可能是内存问题。掌握free、vmstat、sar三大命令,快速排查内存使用情况。free查看实时内存,vmstat诊断系统整体性能瓶颈,sar实现长期监控,三者结合,高效定位并解决内存问题。
375 0
Linux内存问题排查命令详解