天天看点

shell字符串操作集

声明:以下内容来自互联网

1、<b>如果去掉字符串后面的“/”?</b>

例如:/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}'

达到了目的,但感觉不爽,请更好方法

sed  's/\/$//g' ufile

echo ${x%//}

来自netman的13问

file=/dir1/dir2/dir3/my.file.txt

我們可以用 ${ } 分別替換獲得不同的值:

${file#*/}:拿掉第一條 / 及其左邊的字串:dir1/dir2/dir3/my.file.txt

${file##*/}:拿掉最後一條 / 及其左邊的字串:my.file.txt

${file#*.}:拿掉第一個 .  及其左邊的字串:file.txt

${file##*.}:拿掉最後一個 .  及其左邊的字串:txt

${file%/*}:拿掉最後條 / 及其右邊的字串:/dir1/dir2/dir3

${file%%/*}:拿掉第一條 / 及其右邊的字串:(空值)

${file%.*}:拿掉最後一個 .  及其右邊的字串:/dir1/dir2/dir3/my.file

${file%%.*}:拿掉第一個 .  及其右邊的字串:/dir1/dir2/dir3/my

記憶的方法為:

# 是去掉左邊(在鑑盤上 # 在 $ 之左邊)

% 是去掉右邊(在鑑盤上 % 在 $ 之右邊)

單一符號是最小匹配﹔兩個符號是最大匹配。

得到长度

CODE:

%x="abcd"

#方法一

%expr length $x

4

# 方法二

%echo ${#x}

# 方法三

%expr "$x" : ".*"

# expr 的帮助

# STRING : REGEXP   anchored pattern match of REGEXP in STRING

查找子串

%expr index  $x "b"

2

%expr index  $x "a"

1

%expr index  $x "c"

3

%expr index  $x "d"

得到子字符串

# 方法一

# expr &lt;string&gt; 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}

%echo ${x:2}

cd

%echo ${x:0}

%echo ${x:0:2}

ab

%pos=1

%len=2

%echo ${x:$pos:$len}

bc

匹配正则表达式

# 打印匹配长度

%expr match $x "."

%expr match $x "abc"

%expr match $x "bc"

字符串的掐头去尾

%x=aabbaarealwwvvww

%echo "${x%w*w}"

aabbaarealwwvv

%echo "${x%%w*w}"

aabbaareal

%echo "${x##a*a}"

lwwvvww

%echo "${x#a*a}"

bbaarealwwvvww

其中 , # 表示掐头, 因为键盘上 # 在 $ 的左面。

其中 , % 表示%,  因为键盘上 % 在 $ 的右面。

单个的表示最小匹配,双个表示最大匹配。

也就是说,当匹配的有多种方案的时候,选择匹配的最大长度还是最小长度。

字符串的替换

%x=abcdabcd

%echo ${x/a/b} # 只替换一个

bbcdabcd

%echo ${x//a/b} # 替换所有

bbcdbbcd

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

    本文转自eyjian 51CTO博客,原文链接:http://blog.51cto.com/mooon/908799,如需转载请自行联系原作者