轉載:http://www.51testing.com/?uid-225738-action-viewspace-itemid-218002
Shell處理
字串方法(備查)
一、構造字串
直接構造
STR_ZERO=hello
STR_FIRST="i am a string"
STR_SECOND='success'
重複多次
#repeat the first parm($1) by $2 times
strRepeat()
{
local x=$2
if [ "$x" == "" ]; then
x=0
fi
local STR_TEMP=""
while [ $x -ge 1 ];
do
STR_TEMP=`printf "%s%s" "$STR_TEMP" "$1"`
x=`expr $x - 1`
done
echo $STR_TEMP
}
舉例:
STR_REPEAT=`strRepeat "$USER_NAME" 3`
echo "repeat = $STR_REPEAT"
二、賦值與拷貝
直接賦值
與構造字串一樣
USER_NAME=terry
從變數賦值
ALIASE_NAME=$USER_NAME
三、聯結
直接聯結兩個字串
STR_TEMP=`printf "%s%s" "$STR_ZERO" "$USER_NAME"`
使用printf可以進行更複雜的聯結
四、求長
擷取字串變數的長度:${#string}
求字元數(char)
COUNT_CHAR=`echo "$STR_FIRST" | wc -m`
echo $COUNT_CHAR
求位元組數(byte)
COUNT_BYTE=`echo "$STR_FIRST" | wc -c`
echo $COUNT_BYTE
求字數(word)
COUNT_WORD=`echo "$STR_FIRST" | wc -w`
echo $COUNT_WORD
五、比較
相等比較 str1 = str2
不等比較 str1 != str2
舉例:
if [ "$USER_NAME" = "terry" ]; then
echo "I am terry"
fi
小於比較
#return 0 if the two string is equal, return 1 if $1 < $2, else 2strCompare() { local x=0 if [ "$1" != "$2" ]; then x=2 localTEMP=`printf "%s/n%s" "$1" "$2"` local TEMP2=`(echo "$1"; echo "$2") |sort` if [ "$TEMP" = "$TEMP2" ]; then x=1 fi fi echo $x }
六、測試
判空 -z str
判非空 -n str
是否為數字
# return 0 if the string is num, otherwise 1
strIsNum()
{
local RET=1
if [ -n "$1" ]; then
local STR_TEMP=`echo "$1" | sed 's/[0-9]//g'`
if [ -z "$STR_TEMP" ]; then
RET=0
fi
fi
echo $RET
}
舉例:
if [ -n "$USER_NAME" ]; then
echo "my name is NOT empty"
fi
echo `strIsNum "9980"`
七、分割
以符號+為準,將字元分割為左右兩部分
使用sed
舉例:
命令 date --rfc-3339 seconds 的輸出為
2007-04-14 15:09:47+08:00
取其+左邊的部分
date --rfc-3339 seconds | sed 's/+[0-9][0-9]:[0-9][0-9]//g'
輸出為
2007-04-14 15:09:47
取+右邊的部分
date --rfc-3339 seconds | sed 's/.*+//g'
輸出為
08:00
以空格為分割符的字串分割
使用awk
舉例:
STR_FRUIT="Banana 0.89 100"
取第3欄位
echo $STR_FRUIT | awk '{ print $3; }'
八、子字串
字串1是否為字串2的子字串
# return 0 is $1 is substring of $2, otherwise 1
strIsSubstring()
{
local x=1
case "$2" in
*$1*) x=0;;
esac
echo $x
}Shell字串截取一、Linux 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
二、按指定的字串截取
1、第一種方法:
- ${varible##*string} 從左向右截取最後一個string後的字串
- ${varible#*string}從左向右截取第一個string後的字串
- ${varible%%string*}從右向左截取最後一個string後的字串
- ${varible%string*}從右向左截取第一個string後的字串
“*”只是一個萬用字元可以不要
例子:
$ MYVAR=foodforthought.jpg
$ echo ${MYVAR##*fo}
rthought.jpg
$ echo ${MYVAR#*fo}
odforthought.jpg
2、第二種方法:${varible:n1:n2}:截取變數varible從n1開始的n2個字元,組成一個子字串。可以根據特定字元位移和長度,使用另一種形式的變數擴充,來選擇特定子字串。試著在 bash 中輸入以下行:
$ EXCLAIM=cowabunga
$ echo ${EXCLAIM:0:3}
cow
$ echo ${EXCLAIM:3:7}
abunga
這種形式的字串截斷非常簡便,只需用冒號分開來指定起始字元和子字串長度。
三、按照指定要求分割:
比如擷取尾碼名
ls -al | cut -d “.” -f2
shell (bash) 比較子
運算子 |
描述 |
樣本 |
檔案比較子 |
-efilename |
如果filename存在,則為真 |
[ -e /var/log/syslog ] |
-dfilename |
如果filename為目錄,則為真 |
[ -d /tmp/mydir ] |
-ffilename |
如果filename為常規檔案,則為真 |
[ -f /usr/bin/grep ] |
-Lfilename |
如果filename為符號連結,則為真 |
[ -L /usr/bin/grep ] |
-rfilename |
如果filename可讀,則為真 |
[ -r /var/log/syslog ] |
-wfilename |
如果filename可寫,則為真 |
[ -w /var/mytmp.txt ] |
-xfilename |
如果filename可執行,則為真 |
[ -L /usr/bin/grep ] |
filename1-ntfilename2 |
如果filename1比filename2新,則為真 |
[ /tmp/install/etc/services -nt /etc/services ] |
filename1-otfilename2 |
如果filename1比filename2舊,則為真 |
[ /boot/bzImage -ot arch/i386/boot/bzImage ] |
字串比較運算子[size=-1](請注意引號的使用,這是防止空格擾亂代碼的好方法) |
-zstring |
如果string長度為零,則為真 |
[ -z "$myvar" ] |
-nstring |
如果string長度非零,則為真 |
[ -n "$myvar" ] |
string1=string2 |
如果string1與string2相同,則為真 |
[ "$myvar" = "one two three" ] |
string1!=string2 |
如果string1與string2不同,則為真 |
[ "$myvar" != "one two three" ] |
算術比較子 |
num1-eqnum2 |
等於 |
[ 3 -eq $mynum ] |
num1-nenum2 |
不等於 |
[ 3 -ne $mynum ] |
num1-ltnum2 |
小於 |
[ 3 -lt $mynum ] |
num1-lenum2 |
小於或等於 |
[ 3 -le $mynum ] |
num1-gtnum2 |
大於 |
[ 3 -gt $mynum ] |
num1-genum2 |
大於或等於 |
[ 3 -ge $mynum ] |