前言
現在每次分析網站日志的時候都需要判斷百度蜘蛛是不是真實的蜘蛛,nslookup之后需要判斷結果中是否包含“baidu”字符串
以下給出一些shell中判斷字符串包含的方法,來源程序員問答網站 stackoverflow 以及segmentfault。
方法一:利用grep查找
strA="long string"
strB="string"
result=$(echo $strA | grep "${strB}")
if [[ "$result" != "" ]]
then
echo "包含"
else
echo "不包含"
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
這個也挺復雜
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
您可能感興趣的文章:- Shell中判斷字符串是否為數字的6種方法分享
- shell字符串比較判斷是否為數字
- Shell腳本計算字符串長度和判斷字符串為空小技巧
- linux shell判斷字符串為空的正確方法示例