Shell 腳本字符串處理
删除子串
一下方法都可以用来删除字符串中的指定子串
语法 | 作用 | 说明 |
---|---|---|
${str#rule} |
从左开始匹配 | 最小匹配 |
${str##rule} |
从做开始匹配 | 最大匹配 |
${str%rule} |
从右开始匹配 | 最小匹配 |
${str%%rule} |
从右开始匹配 | 最大匹配 |
str 表示字符串变量
举例:
假如 ws="to be or not to be, that's a question"
,那么:
${ws#*to}
: be or not to be, that's a questio$(ws##*to)
: be, that's a questio${ws%to*}
: to be or no${ws%%to*}
: (空字符串)
因为 # 从左开始匹配,所以 %{ws#to*} 这种写法基本是无意义的,因为他只会匹配到字符串的开头,与 \({ws\)to} 是等价的,即如果字符串以 to 开头则删除 to,否则啥也不做。同理 \({ws%*to} 这种写法基本也也是无意义的。 其实稍微想一下不难理解,其实 # 的作用就是删除字符串中特定字符左侧的字符,% 则是删除特定字符右侧的字符。比如要提取文件名和文件后缀的时候就可以分别使用 `\){file_name%.*}
和
%{file_name##*.}`(这里的写法无法处理 xxx.tar.gz 这种“后缀”中包含 . 的文件)
字符串替换
语法 | 作用 | 说明 |
---|---|---|
${str/from/to} |
把 from 替换为 to | 只会替换 from 第一个字符 |
${str//from/to} |
把 from 替换为 to | 会替换整个 from 字符串 |
在部分bash中兩者可能會等效
获取字符串长度
通过 ${#str} 可获取字符串长度,幸运的是这个方法对中文是友善的 —— 如果 str="我就是太阳"
那么 ${#str} 的值会是 5,与人所理解的字符长度一致。
字符串截取
你可以像其他语言中的切片一样对 Shell 的字符串进行截取。
语法 | 作用 | 说明 |
---|---|---|
${str:position} |
截取 str 第 positin 个字符右侧字符 | 注意:不包括第 position 个字符 |
${str:position:len} |
截取 str 第 position 个字符右侧 len 个字符 | 注意:不包括第 position 个字符 |
${str: -position} |
截取 str 倒数第 position 个字符右侧字符 | 注意:不包括倒数第 position 个字符 |
${str: -position:len} |
截取 str 倒数第 position 个字符右侧 len 个字符 | 注意:不包括倒数第 position 个字符 |
注意:
- 此处的字符串以 1 作为第一个字符串索引
- 从右侧开始截取的时候,
:
(冒号)和-
(负号)之间又一个空格,不可省略