字符串的截取拼接
一、字符串的截取
表达式 | 含义 |
---|---|
${#string} | $string的字符个数 |
${string:position} | 在$string中, 从位置$position开始提取子串 |
${string:position:length} | 在$string中, 从位置position开始提取长度为length的子串 |
${string#substring} | 从 变量$string的开头, 删除最短匹配$substring的子串 |
${string##substring} | 从 变量$string的开头, 删除最长匹配$substring的子串 |
${string%substring} | 从 变量$string的结尾, 删除最短匹配$substring的子串 |
${string%%substring} | 从 变量$string的结尾, 删除最长匹配$substring的子串 |
${string/substring/replacement} | 使用$replacement, 来代替第一个匹配的$substring |
${string//substring/replacement} | 使用$replacement, 代替所有匹配的$substring |
${string/#substring/replacement} | 如果$string的前缀匹配substring, 那么就用replacement来代替匹配到的$substring |
${string/%substring/replacement} | 如果$string的后缀匹配substring, 那么就用replacement来代替匹配到的$substring |
expr match "$string" '$substring' | 匹配$string开头的$substring* 的长度 |
expr "$string" : '$substring' | 匹 配$string开头的$substring* 的长度 |
expr index "$string" $substring | 在$string中匹配到的$substring的第一个字符出现的位置 |
expr substr $string $position $length | 在$string中 从位置position开始提取长度为length的子串 |
expr match "$string" '\($substring\)' | 从$string的 开头位置提取$substring* |
expr "$string" : '\($substring\)' | 从$string的 开头位置提取$substring* |
expr match "$string" '.*\($substring\)' | 从$string的 结尾提取$substring* |
expr "$string" : '.*\($substring\)' | 从$string的 结尾提取$substring* |
# 1、# 号从左边开始,删除第一次匹配到条件的左边字符,保留右边字符
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a#*/};echo $b
# 结果:openshift/origin-metrics-cassandra:v3.9
1
2
3
2
3
# 2、## 号从左边开始,删除最后一次匹配到条件的左边字符,保留右边字符
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a##*/};echo $b
# 结果:origin-metrics-cassandra:v3.9
1
2
3
2
3
# 3、%号从右边开始,删除第一次匹配到条件的右边内容,保留左边字符(不保留匹配条件)
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a%/*};echo $b
# 结果:docker.io/openshift
1
2
3
2
3
# 4、%% 号从右边开始,删除最后一次匹配到条件的右边内容,保留左边字符(不保留匹配条件)
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a%%/*};echo $b
# 结果:docker.io
1
2
3
2
3
# 5、从左边第几个字符开始,及字符的个数
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a:0:5};echo $b
# 结果:docke
1
2
3
2
3
# 6、从左边第几个字符开始,一直到结束
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a:7};echo $b
# 结果:io/openshift/origin-metrics-cassandra:v3.9
1
2
3
2
3
# 7、从右边第几个字符开始,向右截取 length 个字符。
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a:0-8:5};echo $b
# 结果:dra:v
1
2
3
2
3
# 8、从右边第几个字符开始,一直到结束
# 样本: a="docker.io/openshift/origin-metrics-cassandra:v3.9"
b=${a:0-8};echo $b
# 结果:dra:v3.9
1
2
3
2
3
# 9、截取字符串中的ip
# 样本: a="当前 IP:123.456.789.172 来自于:中国 上海 上海 联通"
b=${a//[!0-9.]/};echo $b
或者
echo $a | grep -o -E "[0-9]+\.[0-9]+\.[0-9]+\.[0-9]*"
# 结果:123.456.789.172
1
2
3
4
5
6
7
2
3
4
5
6
7
# 10、提取字符串中的数字
echo "test-v1.1.0" | tr -cd '[0-9.]' # 输出1.1.0
aa="test-v1.1.0" | echo ${aa//[!0-9.]/} # 输出1.1.0
1
2
2
上次更新: 2023/02/24, 20:47:23