shell 字符串包含


轉自:Shell判斷字符串包含關系的幾種方法

 

現在每次分析網站日志的時候都需要判斷百度蜘蛛是不是真實的蜘蛛,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 的特性,最為簡潔。

 

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

復制代碼
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
復制代碼

這個也挺復雜

 

 

如果到stackoverflow上看其實還有更多形式,不過基本都屬於以上幾類了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM