shell字符串操作集

声明:以下内容来自互联网
1、 如果去掉字符串后面的“/”?
例如:/a/b/c//
如何变成
/a/b/c

用一个土的办法:
x=/a/b/c//
echo $x|awk -F"//" '{print $1}'
效果:
root@x:~# x=/a/b/c//
root@x:~# echo $x|awk -F"//" '{print $1}'
/a/b/c

达到了目的,但感觉不爽,请更好方法
 
sed  's/\/$//g' ufile
 
x=/a/b/c//
echo ${x%//}
 
来自netman的13问

file=/dir1/dir2/dir3/my.file.txt
我��可以用 ${ } 分�e替�Q�@得不同的值:
${file#*/}:拿掉第一�l / 及其左�的字串:dir1/dir2/dir3/my.file.txt
${file##*/}:拿掉最後一�l / 及其左�的字串:my.file.txt
${file#*.}:拿掉第一�� .  及其左�的字串:file.txt
${file##*.}:拿掉最後一�� .  及其左�的字串:txt
${file%/*}:拿掉最後�l / 及其右�的字串:/dir1/dir2/dir3
${file%%/*}:拿掉第一�l / 及其右�的字串:(空值)
${file%.*}:拿掉最後一�� .  及其右�的字串:/dir1/dir2/dir3/my.file
${file%%.*}:拿掉第一�� .  及其右�的字串:/dir1/dir2/dir3/my
���的方法�椋�

# 是去掉左�(在�a�P上 # 在 $ 之左�)
% 是去掉右�(在�a�P上 % 在 $ 之右�)
�我环��是最小匹配�r���符�是最大匹配。
 
得到长度

[Copy to clipboard]   [   -  ]
CODE:
%x="abcd"
#方法一
%expr length $x
4
# 方法二
%echo ${#x}
4
# 方法三
%expr "$x" : ".*"
4
# expr 的帮助
# STRING : REGEXP   anchored pattern match of REGEXP in STRING

查找子串

[Copy to clipboard]   [   -  ]
CODE:
%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

得到子字符串

[Copy to clipboard]   [   -  ]
CODE:
# 方法一
# 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

匹配正则表达式

[Copy to clipboard]   [   -  ]
CODE:
# 打印匹配长度
%expr match $x "."
1
%expr match $x "abc"
3
%expr match $x "bc"
0

字符串的掐头去尾

[Copy to clipboard]   [   -  ]
CODE:
%x=aabbaarealwwvvww
%echo "${x%w*w}"
aabbaarealwwvv
%echo "${x%%w*w}"
aabbaareal
%echo "${x##a*a}"
lwwvvww
%echo "${x#a*a}"
bbaarealwwvvww

其中 , # 表示掐头, 因为键盘上 # 在 $ 的左面。
其中 , % 表示%,  因为键盘上 % 在 $ 的右面。
单个的表示最小匹配,双个表示最大匹配。
也就是说,当匹配的有多种方案的时候,选择匹配的最大长度还是最小长度。

字符串的替换

[Copy to clipboard]   [   -  ]
CODE:
%x=abcdabcd
%echo ${x/a/b} # 只替换一个
bbcdabcd
%echo ${x//a/b} # 替换所有
bbcdbbcd

不可以使用 regexp , 只能用 * ? 的文件扩展方式。

 

你可能感兴趣的:(互联网,字符串,声明)