前言
現(xiàn)在每次分析網(wǎng)站日志的時(shí)候都需要判斷百度蜘蛛是不是真實(shí)的蜘蛛,nslookup之后需要判斷結(jié)果中是否包含“baidu”字符串
以下給出一些shell中判斷字符串包含的方法,來(lái)源程序員問(wèn)答網(wǎng)站 stackoverflow 以及segmentfault。
方法一:利用grep查找
strA="long string"
strB="string"
result=$(echo $strA | grep "${strB}")
if [[ "$result" != "" ]]
then
echo "包含"
else
echo "不包含"
fi
先打印長(zhǎng)字符串,然后在長(zhǎng)字符串中 grep 查找要搜索的字符串,用變量result記錄結(jié)果
如果結(jié)果不為空,說(shuō)明strA包含strB。如果結(jié)果為空,說(shuō)明不包含。
這個(gè)方法充分利用了grep 的特性,最為簡(jiǎn)潔。
方法二:利用字符串運(yùn)算符
strA="helloworld"
strB="low"
if [[ $strA =~ $strB ]]
then
echo "包含"
else
echo "不包含"
fi
利用字符串運(yùn)算符 =~ 直接判斷strA是否包含strB。(這不是比第一個(gè)方法還要簡(jiǎn)潔嗎?。?/p>
方法三:利用通配符
A="helloworld"
B="low"
if [[ $A == *$B* ]]
then
echo "包含"
else
echo "不包含"
fi
這個(gè)也很easy,用通配符*號(hào)代理strA中非strB的部分,如果結(jié)果相等說(shuō)明包含,反之不包含。
方法四:利用case in 語(yǔ)句
thisString="1 2 3 4 5" # 源字符串
searchString="1 2" # 搜索字符串
case $thisString in
*"$searchString"*) echo Enemy Spot ;;
*) echo nope ;;
esa
這個(gè)就比較復(fù)雜了,case in 我還沒(méi)有接觸到,不過(guò)既然有比較簡(jiǎn)單的方法何必如此
方法五:利用替換
STRING_A=$1
STRING_B=$2
if [[ ${STRING_A/${STRING_B}//} == $STRING_A ]]
then
## is not substring.
echo N
return 0
else
## is substring.
echo Y
return 1
fi
這個(gè)也挺復(fù)雜
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
您可能感興趣的文章:- Shell中判斷字符串是否為數(shù)字的6種方法分享
- shell字符串比較判斷是否為數(shù)字
- Shell腳本計(jì)算字符串長(zhǎng)度和判斷字符串為空小技巧
- linux shell判斷字符串為空的正確方法示例