获取长度:
%x="abcd"
#方法一
%expr length $x
4
# 方法二
%echo ${#x}
4
# 方法三
%expr "$x" : ".*"
4
# expr 的帮助
# STRING : REGEXP anchored pattern match of REGEXP in STRING 查找子串:
%expr index $x "b"
2
%expr index $x "a"
1
%expr index $x "b"
2
%expr index $x "c"
3
%expr index $x "d"
4
获取子字符串:
# 方法一
# expr <string> startpos length
%expr substr "$x" 1 3
abc
%expr substr "$x" 1 5
abcd
%expr substr "$x" 2 5
bcd
# 方法二
# ${x:pos:lenght}
%echo ${x:1}
bcd
%echo ${x:2}
cd
%echo ${x:0}
abcd
%echo ${x:0:2}
ab
%pos=1
%len=2
%echo ${x:$pos:$len}
bc
匹配正则表达式:
# 打印匹配长度
%expr match $x "."
1
%expr match $x "abc"
3
%expr match $x "bc"
0
字符串的掐头去尾:
%x=aabbaarealwwvvww
%echo "${x%w*w}"
aabbaarealwwvv
%echo "${x%%w*w}"
aabbaareal
%echo "${x##a*a}"
lwwvvww
%echo "${x#a*a}"
bbaarealwwvvww
其中 , # 表示掐头, 因为键盘上 # 在 $ 的左面。
其中 , % 表示%, 因为键盘上 % 在 $ 的右面。
单个的表示最小匹配,双个表示最大匹配。
也就是说,当匹配的有多种方案的时候,选择匹配的最大长度还是最小长度。
按给定字符串截取(.)可任意,变量为(a)
${变量##*string}从左向右截取保留 最后一个string后的字符串
${变量#*string}从左向右截取保留 第一个string后的字符串
${变量%%string*}从右向左截取保留 最后一个string后的字符串
${变量%string*}从右向左截取保留 第一个string后的字符串
“*”是一个通配符
例子如下:
a="mine.mv.avi"
1.echo ${a##*.} 执行结果:avi
2.echo ${a#*.} 执行结果:mv.avi
3.echo ${a%%.*} 执行结果:mine
4.echo ${a%.*} 执行结果:mine.mv
按字符串位数截取
shell 截取字符变量的前8位,有方法如下:
1.expr substr “$a” 1 8
2.echo $a|awk ‘{print substr(,1,8)}’
3.echo $a|cut -c1-8
4.echo $
5.expr $a : ‘\(.\\).*’
6.echo $a|dd bs=1 count=8 2>/dev/null
按指定的字符串截取
上面带例子的是第一种方法。
还有一种方法:${varible:n1:n2}:截取变量varible从n1到n2之间的字符串。
可以根据特定字符偏移和长度,使用另一种形式的变量扩展,来选择特定子字符串。试着在 bash 中输入以下行:
a=abcdefg
echo ${a:0:5} 执行结果为:abcde
echo ${a:3:7} 执行结果为:defg
这种形式的字符串截断非常简便,只需用冒号分开来指定起始字符和子字符串长度。
按照指定要求分割:
比如获取后缀名
ls -al | cut -d “.” -f2
awk和grep,cat,sed比较适合截取大段字符
字符串的替换:
%x=abcdabcd
%echo ${x/a/b} # 只替换一个
bbcdabcd
%echo ${x//a/b} # 替换所有
bbcdbbcd
不可以使用regexp,只能用* ?的文件扩展方式。
329

被折叠的 条评论
为什么被折叠?



