shell变量操作${}详细用法

${}基本功能

一般情况下$var与${var}是没有区别的,但是用${ }会比较精确的界定变量名称的范围

[root@localhost ~]# A=Linux
[root@localhost ~]# echo $AB    #表示变量AB

[root@localhost ~]# echo ${A}B    #表示变量A后连接着B
LinuxB

除此之外${}还有很多其他功能如下:

先声明测试变量:

file=/dir1/dir2/dir3/my.file.txt

取子串及替换

命令解释结果
${file:0:5}提取最左边的 5 个字节/dir1
${file:5:5}提取第 5 个字节右边的连续 5 个字节/dir2
${file/dir/path}将第一个 dir 提换为 path/path1/dir2/dir3/my.file.txt
${file//dir/path}将全部 dir 提换为 path/path1/path2/path3/my.file.txt
${#file}获取变量长度27

根据状态为变量赋值

命令解释备注
${file-my.file.txt}若 $file 没设定,则使用 my.file.txt 作传回值有设定( 空值及非空值)不作处理
${file:-my.file.txt}若 $file 没设定或为空值,则使用 my.file.txt 作传回值非空值时不作处理
${file+my.file.txt}若$file 有设定(空值或非空值),均使用my.file.txt作传回值没设定时不作处理
${file:+my.file.txt}若 $file 有设定且不为空值(为非空值),则使用 my.file.txt 作传回值没设定及空值不作处理
${file=txt}若 $file 没设定,则回传 txt ,并将 $file 赋值为 txt有设定( 空值及非空值)不作处理
${file:=txt}若 $file 没设定或空值,则回传 txt ,将 $file 赋值为txt非空值时不作处理
${file?my.file.txt}若 $file 没设定,则将 my.file.txt 输出至 STDERR有设定( 空值及非空值)不作处理
${file:?my.file.txt}若 $file没设定或空值,则将my.file.txt输出至STDERR非空值时不作处理

tips:

以上的理解在于, 你一定要分清楚 unset 与 null 及 non-null 这三种赋值状态. 一般而言, : 与 null 有关, 若不带 : 的话, null 不受影响, 若带 : 则连 null 也受影响.

  • my.file.txt 前的“-”可以理解为“没定义,则替换成word”;“+”可以理解为“有定义,则替换成word”。

  • my.file.txt 前的“?”可以理解为“参数到底定义了没,没定义,把word当错误消息打印出来。”

${}字符串截取

示例如下:
命令 | 解释 | 结果
${file#*.} 拿掉第一个 . 及其左边的字符串 file.txt

[root@localhost ~]# echo ${file#*.} 
file.txt

${file##*.} 拿掉最后一个 . 及其左边的字符串 txt

[root@localhost ~]# echo ${file##*.}
txt

${file%.*} 拿掉最后一个 . 及其右边的字符串 /dir1/dir2/dir3/my.file

[root@localhost ~]# echo ${file%.*}
/dir1/dir2/dir3/my.file

${file%%.*} 拿掉第一个 . 及其右边的字符串 /dir1/dir2/dir3/my

[root@localhost ~]# echo ${file%%.*}
/dir1/dir2/dir3/my
记忆方法如下:
  • # 是去掉左边(在键盘上 # 在 $ 之左边)
  • % 是去掉右边(在键盘上 % 在 $ 之右边)
  • 单一符号是最小匹配;两个符号是最大匹配
  • *是用来匹配不要的字符,也就是想要去掉的那部分
  • 还有指定字符分隔号,与*配合,决定取哪部分

上面是网上的解释,按照上面示例,好像${}只能用单字符定界,实际可以用字符串,并且也不是只能匹配删除定界字符串的一侧,实际可以两边同时匹配删除(但是因为存在行首或行尾定界,#模式指定匹配行首必删除行首一侧,%模式同理,看下面解释)

补充:经测试发现,实际上这里#和%指代的是匹配字符串开头或者结尾,指定匹配正则中的^或者$。连续的#和$,类似于正则的贪婪匹配和最短匹配,*相当于标准正则中的.* ,类似于的shell命令中的匹配模式。 ${}实际上就是以这种非标准正则的方式匹配字符串,然后截取删除。

示例如下:

${file##/*.fi}最长匹配,但是没有匹配到后面的"." ,因为这里匹配的是"/*.fi",.fi与.txt不匹配,而前面的/*
等价于正则的^/*,可以匹配字符串前面部分。

[root@test ~]# echo ${file##/*.fi}
le.txt

如果换成{file##d*.},因为是匹配字符串开头模式,前面的d*等价于匹配正则的^d*,匹配失败返回原字符串

[root@test ~]# echo ${file##d*.}
/dir1/dir2/dir3/my.file.txt

${file#*.t} 最短匹配,这里匹配是".*t",可以匹配.txt前面部分,结果如下

[root@test ~]# echo ${file#*.*t}
xt

${file%dir*xt} 匹配行尾部分

[root@test ~]# echo ${file%dir*xt}
/dir1/dir2/

这里的*也不是必要的,没有同样可以匹配成功

[root@test ~]# echo ${file%le.txt}
/dir1/dir2/dir3/my.fi

因此${}中#和$就是用类似正则的方式指定匹配行首或者行尾匹配删除字符

数组

A="a b c def"   # 定义变量
A=(a b c def)   # 定义数组
命令解释结果
${A[@]}返回数组全部元素a b c def
${A[*]}同上a b c def
${A[0]}返回数组第一个元素a
${#A[@]}返回数组元素总个数4
${#A[*]}同上4
${#A[3]}返回第四个元素的长度,即def的长度3
A[3]=xzy则是将第四个组数重新定义为 xyz
  • 实际上在shell中变量A和数组元素A[0]是等价的(一个字符串就是只有一个元素的数组)

单独声明变量后,同样可以以数组方式取值

[root@test ~]# B="12 3 4"
[root@test ~]# echo ${B[*]}
12 3 4
[root@test ~]# echo ${#B[*]}
1
[root@test ~]# echo ${B[0]}
12 3 4
  • 5
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LinuxShell脚本中,变量是用来存储和操作数据的符号名称。下面是关于Linux Shell变量详细说明: 1. 变量的定义:可以使用以下方式定义一个变量: ``` variable_name=value ``` 例如: ``` name="John" age=25 ``` 2. 变量的命名规则: - 变量名由字母、数字和下划线组成,但不能以数字开头。 - 变量名区分大小写。 - 推荐使用大写字母来定义环境变量,而使用小写字母来定义普通变量。 3. 变量的使用: - 使用变量时,可以通过在变量前加上美元符号($)来引用变量的值。例如:`$variable_name` - 也可以使用花括号({})来明确变量名的边界。例如:`${variable_name}` - 可以将变量的值赋给其他变量,或者将其作为命令的参数。 4. 特殊变量: - `$0`:当前脚本的文件名。 - `$1`、`$2`、...:命令行参数,表示第一个、第二个等参数。 - `$@`:所有命令行参数的列表。 - `$#`:命令行参数的个数。 - `$?`:上一个命令的退出状态码。 - `$$`:当前Shell进程的进程ID。 5. 环境变量: - 环境变量是全局的变量,可以被所有Shell脚本和命令访问。 - 可以使用 `export` 命令将普通变量导出为环境变量。 - 常见的环境变量包括 `PATH`(指定可执行文件的搜索路径)、`HOME`(用户的主目录)等。 6. 删除变量: - 可以使用 `unset` 命令删除一个变量。例如:`unset variable_name` 这些是关于Linux Shell变量的一些基本概念和用法。使用变量可以方便地存储和操作数据,提高脚本的灵活性和可重用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值