bash 括号使用
Bash 括号多种使用方式
${}
变量初始化
${param:-string}
若变量
param为空或者未定义,则用在命令行中用string来替换${param:-string}否则变量
param不为空时,则用变量param的值来替换${param:-string}[root@test-lb-010000006199 ~]# echo $param [root@test-lb-010000006199 ~]# echo ${param:-strabc}
strabc
[root@test-lb-010000006199 ~]# param="default"
[root@test-lb-010000006199 ~]# echo $param
default
[root@test-lb-010000006199 ~]# echo ${param:-strabc}
default
[root@test-lb-010000006199 ~]#
${param:+string}
与
${param:-string}相反若变量
param不为空或者未定义,则用在命令行中用string来替换${param:-string}否则变量
param为空时,则用变量param的值来替换${param:-string}[root@test-lb-010000006199 ~]# unset param
[root@test-lb-010000006199 ~]# echo $param [root@test-lb-010000006199 ~]# echo ${param:+strabc} [root@test-lb-010000006199 ~]# param="default"
[root@test-lb-010000006199 ~]# echo ${param:+strabc}
strabc
[root@test-lb-010000006199 ~]#
${param:=string}
param为空时,把string赋值给param[root@test-app-010000006205 ~]# unset param
[root@test-app-010000006205 ~]# echo $param [root@test-app-010000006205 ~]# echo ${param:=teststr}
teststr
[root@test-app-010000006205 ~]# echo $param
teststr
[root@test-app-010000006205 ~]#
${param:?string}
替换规则:若变量
param不为空,则用变量param的值来替换${param:?string}若变量
param为空,则把string输出到标准错误中,并从脚本中退出。可利用此特性来检查是否设置了变量的值
[root@test-app-010000006205 ~]# unset param
[root@test-app-010000006205 ~]# echo $param [root@test-app-010000006205 ~]# echo ${param:?`date "+%F %T"`}
-bash: param: 2019-07-24 14:57:07
[root@test-app-010000006205 ~]# echo $?
1
[root@test-app-010000006205 ~]# param="test"
[root@test-app-010000006205 ~]# echo $param
test
[root@test-app-010000006205 ~]# echo ${param:?`date "+%F %T"`}
test
[root@test-app-010000006205 ~]# echo $?
0
[root@test-app-010000006205 ~]#
变量截取
去掉
第一次匹配的值以及左边的字符[root@test-app-010000006205 ~]# str="java spring,go kubernetes"
[root@test-app-010000006205 ~]# echo $str
java spring,go kubernetes
[root@test-app-010000006205 ~]# echo ${str#*e}
rnetes
[root@test-app-010000006205 ~]#
去掉
最后一次匹配的值以及左边的字符[root@test-app-010000006205 ~]# str="java spring,go kubernetes"
[root@test-app-010000006205 ~]# echo $str
java spring,go kubernetes
[root@test-app-010000006205 ~]# echo ${str##*e}
s
[root@test-app-010000006205 ~]#
去掉
第一次匹配的值以及右边的字符[root@test-app-010000006205 ~]# str="java spring,go kubernetes"
[root@test-app-010000006205 ~]# echo $str
java spring,go kubernetes
[root@test-app-010000006205 ~]# echo ${str%e*}
java spring,go kubernet
[root@test-app-010000006205 ~]#
去掉
最后一次匹配的值以及右边的字符[root@test-app-010000006205 ~]# str="java spring,go kubernetes"
[root@test-app-010000006205 ~]# echo $str
java spring,go kubernetes
[root@test-app-010000006205 ~]# echo ${str%%e*}
java spring,go kub
[root@test-app-010000006205 ~]#
截取字符串
[root@test-app-010000006205 ~]# str="123456789"
[root@test-app-010000006205 ~]# echo $str
123456789
[root@test-app-010000006205 ~]# echo ${str:0-3}
789
[root@test-app-010000006205 ~]# echo ${str:3}
456789
[root@test-app-010000006205 ~]# echo ${str:3:1}
4
模糊匹配
[root@test-app-010000006205 ~]# touch 1{4,5,6,7}.a
[root@test-app-010000006205 ~]# ll
total 0
-rw-r--r-- 1 root root 0 Jul 24 15:14 123.a
-rw-r--r-- 1 root root 0 Jul 24 15:14 124.a
-rw-r--r-- 1 root root 0 Jul 24 15:15 14.a
-rw-r--r-- 1 root root 0 Jul 24 15:15 15.a
-rw-r--r-- 1 root root 0 Jul 24 15:15 16.a
-rw-r--r-- 1 root root 0 Jul 24 15:15 17.a
[root@test-app-010000006205 ~]# ls 1{2,4,5}*.a
123.a 124.a 14.a 15.a
[root@test-app-010000006205 ~]#
[] [[]]
- []
是bash` 的内部命令,test是等同的.如果我们不用绝对路径指明,通常我们用的都是bash自带的命令.if/test结构中的左中括号是调用test的命令标识,右中括号是关闭条件判断的.这个命令把它的参数作为比较表达式或者作为文件测试,并且根据比较的结果来返回一个退出状态码.if/test结构中并不是必须右中括号,但是新版的Bash中要求必须这样 - Test和[]中可用的比较运算符只有==和!=,两者都是用于字符串比较的,不可用于整数比较,整数比较只能使用-eq,-gt这种形式.无论是字符串比较还是整数比较都不支持大于号小于号.如果实在想用,对于字符串比较可以使用转义形式,如果比较"ab"和"bc":[ ab < bc ],结果为真,也就是返回状态为0.[ ]中的逻辑与和逻辑或使用-a 和-o 表示
- [[是 bash 程序语言的关键字.并不是一个命令,[[ ]] 结构比[ ]结构更加通用.在[[和]]之间所有的字符都不会发生文件名扩展或者单词分割,但是会发生参数扩展和命令替换.
- 支持字符串的模式匹配,使用=~操作符时甚至支持shell的正则表达式.字符串比较时可以把右边的作为一个模式,而不仅仅是一个字符串,比如[[ hello == hell? ]],结果为真.[[ ]] 中匹配字符串或通配符,不需要引号.
- 使用[[ ... ]]条件判断结构,而不是[ ... ],能够防止脚本中的许多逻辑错误.比如,&&,||,<和> 操作符能够正常存在于[[ ]]条件判断结构中,但是如果出现在[ ]结构中的话,会报错.比如可以直接使用
if [[ $a != 1 && $a != 2 ]], 如果不适用双括号, 则为if [ $a -ne 1] && [ $a != 2 ]或者if [ $a -ne 1 -a $a != 2 ]
() (())
()
- 命令组.括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用.括号中多个命令之间用分号隔开,最后一个命令可以没有分号,各命令和括号之间不必有空格.
- 命令替换.等同于`cmd`,shell扫描一遍命令行,发现了
$(cmd)结构,便将$(cmd)中的cmd执行一次,得到其标准输出,再将此输出放到原来命令.有些shell不支持,如tcsh. - 用于初始化数组.如:array=(a b c d)
(())
- 整数扩展.这种扩展计算是整数型的计算,不支持浮点型.((exp))结构扩展并计算一个算术表达式的值,如果表达式的结果为0,那么返回的退出状态码为1,或者 是"假",而一个非零值的表达式所返回的退出状态码将为0,或者是"true".若是逻辑判断,表达式exp为真则为1,假则为0.
- 只要括号中的运算符,表达式符合C语言运算规则,都可用在
$((exp))中,甚至是三目运算符.作不同进位(如二进制,八进制,十六进制)运算时,输出结果全都自动转化成了十进制.如:echo $((16#5f))结果为95 (16进位转十进制) - 单纯用 (( )) 也可重定义变量值,比如
a=5; ((a++))可将$a重定义为6 - 常用于算术运算比较,双括号中的变量可以不使用
$符号前缀.括号内支持多个表达式用逗号分开. 只要括号中的表达式符合C语言运算规则,比如可以直接使用for((i=0;i<5;i++)), 如果不使用双括号, 则为for i in seq 0 4或者for i in {0..4}.再如可以直接使用if (($i<5)), 如果不使用双括号, 则为if [ $i -lt 5 ].
bash 括号使用的更多相关文章
- bash 括号(小括号,双小括号,中括号,双中括号,大括号)
小括号()和大括号{} 主要包括一下几种 ${var} $(cmd) ()和{} $((exp)) ${var:-string},${var:+string},${var:=string},${var ...
- shell脚本学习之Bash shell 里各种括号的用法
今天在 SegmentFault 上看到又有人问起关于Shell里各种括号的问题.对于很多玩Shell的人,括号是个很尴尬的问题,用起来没问题,说起来不明白,我在这里总结一下Bash Shell几种括 ...
- 【一通百通】Bash的单双括号建议:多用[[]], 少用[]
一. bash [ ] 单双括号 基本要素: Ø [ ] 两个符号左右都要有空格分隔 Ø 内部操作符与操作变量之间要有空格:如 [ “a” = “b” ] Ø 字符串比较中,> ...
- Bash Shell 里的各种括号
天在 SegmentFault 上看到又有人问起关于Shell里各种括号的问题.对于很多玩Shell的人,括号是个很尴尬的问题,用起来没问题,说起来不明白,我在这里总结一下Bash Shell几种括号 ...
- Bash中的括号(三)
1.两个小括号用来对整数进行算术运算和逻辑运算,比如. 例如给变量赋值: $ a=+; echo $a + $ (( b = + )); echo $b 1+1 只是一个字符串,而 b 就是一个算术表 ...
- Bash中的括号(二)
双方括号[[]]的用法: 1.先举个例子说明: 假如你要再判断某个目录是否存在,又想当然写成: $ [ -f exists.txt && -d exists_folder ]; ech ...
- Bash中的括号(一)
初学Bash脚本编程,里面的各种括号,绝对是一个大坑,为了救人救己,以防再度入坑,特记录如下: 一.单小括号: 1.创建子Shell.单个小括号用来创建一个子shell,子shell允许你在不影响当前 ...
- bash 中 小括号的作用
单小括号 () ①命令组.括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用.括号中多个命令之间用分号隔开,最后一个命令可以没有分号,各命令和括号之间不必有空格. ...
- linux下形如{command,parameter,parameter}执行命令 / bash花括号扩展
背景 在复现vulhub上的漏洞ActiveMQ Deserialization Vulnerability (CVE-2015-5254)时,发现官方文档给出反弹shell的payload bash ...
随机推荐
- Effective Objective-C 的读书笔记
本文主要是摘录了 <Effective Objective-C 2.0>一书中提到的编写高质量iOS 代码的几个方法. 1 熟悉Objective -C 1.1 OC 起源 OC 为C语言 ...
- kickstart半自动安装centos系统与pxe自动安装centos系统
一.kickstart半自动安装centos系统 关闭防火墙,关闭selinux,使用system-config-kickstart生成kickstart配置文件,启动xmanger-Passive ...
- [剑指Offer]61-扑克牌中的顺子
题目 "红心A,黑桃3,小王,大王,方片5",大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13.上面的5张牌就可以变成"1,2,3,4,5" ...
- JVM运行时数据区划分
Java内存空间 内存是非常重要的系统资源,是硬盘和cpu的中间仓库及桥梁,承载着操作系统和应用程序的实时运行.JVM内存布局规定了JAVA在运行过程中内存申请.分配.管理的策略,保证了JVM的高效稳 ...
- Win10系统安装Tensorflow-GPU和VSCode构建Tensorflow开发环境
[前言] 1. 最近因为上课需要安装Anaconda和Tensorflow-GPU,Anaconda安装很容易,但Tensorflow-GPU版本的安装较为复杂,因为需要考虑版本匹配的一些问题,很容易 ...
- linux命令之修改yum源为国内镜像
命令: centos7 修改yum源为阿里源 首先是到yum源设置文件夹里 1. 查看yum源信息: yum repolist 2. 安装base reop源 cd /etc/yum.repos.d ...
- Java多线程--公平锁与非公平锁
上一篇文章介绍了AQS的基本原理,它其实就是一个并发包的基础组件,用来实现各种锁,各种同步组件的.它包含了state变量.加锁线程.等待队列等并发中的核心组件,现在我们来看一下多线程获取锁的顺序问题. ...
- chrome禁止三方cookie,网站登录不了怎么办
背景 新版chrome(80+)浏览器默认屏蔽所有三方cookie已经不是什么新闻了,具体原因这里不去深究,有大量相关文章介绍,由于目前许多网站都依赖三方cookie,因此该特性的推出还是造成了一些的 ...
- Java程序运行内存机制
Java程序运行内存机制 栈内存包留调用方法.变量的区域,堆内存是new对象的区域,方法区为保存class文件的区域. 程序刚开始时,先加载类文件相应的数据到方法区,然后就从main()方法开始执行. ...
- Vue 表单拖拽排序
Vue table表单拖拽 业务需求: 因为数据展示使用的是 elementUI 的 Table进行数据展示的,现在的需求是通过拖拽表单进行表单排序.同时,动态修改表单中的数据排列顺序.查阅了好多资料 ...