zoukankan      html  css  js  c++  java
  • 用Shell判断字符串包含关系的方法小结

     这篇文章主要给大家介绍了关于用Shell判断字符串包含关系的几种方法,其中包括利用grep查找、利用字符串运算符、利用通配符、利用case in 语句以及利用替换等方法,每个方法都给出了详细的示例代码与介绍,有需要的朋友们可以参考参考借鉴,下面来一起看看吧。
    前言

    现在每次分析网站日志的时候都需要判断百度蜘蛛是不是真实的蜘蛛,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 的特性,最为简洁。

    方法二:利用字符串运算符

    
    
    1. strA="helloworld"
    2. strB="low"
    3. if [[ $strA =~ $strB ]]
    4. then
    5.   echo "包含"
    6. else
    7.   echo "不包含"
    8. fi
     

    利用字符串运算符 =~ 直接判断strA是否包含strB。(这不是比第一个方法还要简洁吗!)

    方法三:利用通配符

    
    
    1. A="helloworld"
    2. B="low"
    3. if [[ $A == *$B* ]]
    4. then
    5.   echo "包含"
    6. else
    7.   echo "不包含"
    8. fi
     

    这个也很easy,用通配符*号代理strA中非strB的部分,如果结果相等说明包含,反之不包含。

    方法四:利用case in 语句

    
    
    1. thisString="1 2 3 4 5" # 源字符串
    2. searchString="1 2" # 搜索字符串
    3. case $thisString in
    4.   *"$searchString"*) echo Enemy Spot ;;
    5.   *) echo nope ;;
    6. esa
     

    这个就比较复杂了,case in 我还没有接触到,不过既然有比较简单的方法何必如此

    方法五:利用替换

    
    
    1. STRING_A=$1
    2. STRING_B=$2
    3. if [[ ${STRING_A/${STRING_B}//} == $STRING_A ]]
    4.   then
    5.     ## is not substring.
    6.     echo N
    7.     return 0
    8.   else
    9.     ## is substring.
    10.     echo Y
    11.     return 1
    12.   fi

    这个也挺复杂

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

    原文链接:http://www.cnblogs.com/ginsonwang/p/5525340.html

     
  • 相关阅读:
    Qt on Android:将Qt调试信息输出到logcat中
    cheap louis vuitton outlet
    mysql经常使用查询:group by,左连接,子查询,having where
    SQLSERVER 2008 链接 到 ORACLE 11
    uva 11885
    Comet入门及最简单的Java Demo
    什么是BGP线路?什么是BGP机房?
    (LeetCode)旋转数组
    ios app 实现热更新(无需发新版本号实现app加入新功能)
    hdu 4961 Boring Sum(高效)
  • 原文地址:https://www.cnblogs.com/yangcx666/p/8723836.html
Copyright © 2011-2022 走看看