前端之家收集整理的这篇文章主要介绍了
用Shell判断字符串包含关系的方法小结,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
原文地址:http://www.cnblogs.com/ginsonwang/p/5525340.html
这篇
文章主要给大家介绍了关于用Shell判断字符串包含关系的几种
方法,其中
包括利用grep查找、利用字符串运算符、利用
通配符、利用case in 语句以及利用替换等
方法,每个
方法都给出了详细的示例
代码与介绍,有需要的朋友们可以参考参考借鉴,下面来一起看看吧。
前言
现在每次分析网站日志的时候都需要判断百度蜘蛛是不是真实的蜘蛛,nslookup之后需要判断结果中是否包含“baidu”字符串
以下给出一些shell中判断字符串包含的方法,来源程序员问答网站 stackoverflow 以及segmentfault。
方法一:利用grep查找
1
2
3
4
5
6
7
8
9
|
strA=
"long string"
strB=
"string"
result=$(
echo
$strA |
grep
"${strB}"
)
if
[[
"$result"
!=
""
]]
then
echo
"包含"
else
"不包含"
fi
|
先打印长字符串,然后在长字符串中 grep 查找要搜索的字符串,用变量result记录结果
如果结果不为空,说明strA包含strB。如果结果为空,说明不包含。
这个方法充分利用了grep 的特性,最为简洁。
方法二:利用字符串运算符
8
"helloworld"
"low"
[[ $strA =~ $strB ]]
then
"包含"
else
"不包含"
fi
|
利用字符串运算符 =~ 直接判断strA是否包含strB。(这不是比第一个方法还要简洁吗!)
方法三:利用通配符
A=
B=
[[ $A == *$B* ]]
fi
这个也很easy,用通配符*号代理strA中非strB的部分,如果结果相等说明包含,反之不包含。
方法四:利用case in 语句
6
thisString=
"1 2 3 4 5"
@H_301_238@ # 源字符串
searchString=
"1 2"
case
$thisString
in
*
"$searchString"
*)
Enemy Spot ;;
nope ;;
esa
|
这个就比较复杂了,case in 我还没有接触到,不过既然有比较简单的方法何必如此
方法五:利用替换
9
10
11
12
STRING_A=$1
STRING_B=$2
[[ ${STRING_A/${STRING_B}
//
} == $STRING_A ]]
N
return
0
else
## is substring.
Y
1
fi
|
这个也挺复杂
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。