現在每次分析網站日志的時候都需要判斷百度蜘蛛是不是真實的蜘蛛,nslookup之后需要判斷結果中是否包含“baidu”字符串
以下給出一些shell中判斷字符串包含的方法,來源程序員問答網站 stackoverflow 以及segmentfault。
方法一:利用grep查找
1 strA="long string"
2 strB="string"
3 result=$(echo $strA | grep "${strB}")
4 if [[ "$result" != "" ]]
5 then
6 echo "包含"
7 else
8 echo "不包含"
9 fi
先打印長字符串,然后在長字符串中 grep 查找要搜索的字符串,用變量result記錄結果
如果結果不為空,說明strA包含strB。如果結果為空,說明不包含。
這個方法充分利用了grep 的特性,最為簡潔。
方法二:利用字符串運算符
strA="helloworld"
strB="low"
if [[ $strA =~ $strB ]]
then
echo "包含"
else
echo "不包含"
fi
利用字符串運算符 =~ 直接判斷strA是否包含strB。(這不是比第一個方法還要簡潔嗎摔!)
方法三:利用通配符
A="helloworld"
B="low"
if [[ $A == *$B* ]]
then
echo "包含"
else
echo "不包含"
fi
這個也很easy,用通配符*號代理strA中非strB的部分,如果結果相等說明包含,反之不包含。
方法四:利用case in 語句
thisString="1 2 3 4 5" # 源字符串
searchString="1 2" # 搜索字符串
case $thisString in
*"$searchString"*) echo Enemy Spot ;;
*) echo nope ;;
esa
這個就比較復雜了,case in 我還沒有接觸到,不過既然有比較簡單的方法何必如此
方法五:利用替換
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
這個也挺復雜
如果到stackoverflow上看其實還有更多形式,不過基本都屬於以上幾類了。

