如今每次分析網站日誌的時候都須要判斷百度蜘蛛是否是真實的蜘蛛,nslookup以後須要判斷結果中是否包含「baidu」字符串html
如下給出一些shell中判斷字符串包含的方法,來源程序員問答網站 stackoverflow 以及segmentfault。程序員
方法一:利用grep查找shell
- strA="long string"
- strB="string"
- result=$(echo $strA | grep "${strB}")
- if [[ "$result" != "" ]]
- then
- echo "包含"
- else
- echo "不包含"
- fi
先打印長字符串,而後在長字符串中 grep 查找要搜索的字符串,用變量result記錄結果segmentfault
若是結果不爲空,說明strA包含strB。若是結果爲空,說明不包含。markdown
這個方法充分利用了grep 的特性,最爲簡潔。學習
方法二:利用字符串運算符網站
- strA="helloworld"
- strB="low"
- if [[ $strA =~ $strB ]]
- then
- echo "包含"
- else
- echo "不包含"
- fi
利用字符串運算符 =~ 直接判斷strA是否包含strB。(這不是比第一個方法還要簡潔嗎!)this
方法三:利用通配符spa
- 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
這個也挺複雜
總結
以上就是這篇文章的所有內容了,但願本文的內容對你們的學習或者工做能帶來必定的幫助,若是有疑問你們能夠留言交流。
原文連接:http://www.cnblogs.com/ginsonwang/p/5525340.html