如今每次分析网站日志的时候都须要判断百度蜘蛛是否是真实的蜘蛛,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