zoukankan      html  css  js  c++  java
  • 用Shell判断字符串包含关系

    方法一:利用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
  • 相关阅读:
    剑指offer(14)链表中倒数第K个节点
    剑指offer(13)调整数组顺序使奇数位于偶数前面
    跨域资源共享CORS
    同源政策
    剑指offer(12)数值的整数次方
    剑指offer(11)二进制中1的个数
    面试金典——交点
    LeetCode——简化路径
    LeetCode——跳跃游戏 I-II
    LeetCode——最大矩形
  • 原文地址:https://www.cnblogs.com/uestc2007/p/14388685.html
Copyright © 2011-2022 走看看