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 作为第一个字符串索引
 - 从右侧开始截取的时候,
:(冒号)和-(负号)之间又一个空格,不可省略 
                    
                
                
            
        
浙公网安备 33010602011771号