前言
現(xiàn)在每次分析網(wǎng)站日志的時(shí)候都需要判斷百度蜘蛛是不是真實(shí)的蜘蛛,nslookup之后需要判斷結(jié)果中是否包含“baidu”字符串
以下給出一些shell中判斷字符串包含的方法,來(lái)源程序員問(wèn)答網(wǎng)站 stackoverflow 以及segmentfault。
方法一:利用grep查找
strA="long string" strB="string" result=$(echo $strA | grep "${strB}") if [[ "$result" != "" ]] then echo "包含" else echo "不包含" fi
先打印長(zhǎng)字符串,然后在長(zhǎng)字符串中 grep 查找要搜索的字符串,用變量result記錄結(jié)果
如果結(jié)果不為空,說(shuō)明strA包含strB。如果結(jié)果為空,說(shuō)明不包含。
這個(gè)方法充分利用了grep 的特性,最為簡(jiǎn)潔。
方法二:利用字符串運(yùn)算符
strA="helloworld" strB="low" if [[ $strA =~ $strB ]] then echo "包含" else echo "不包含" fi
利用字符串運(yùn)算符 =~ 直接判斷strA是否包含strB。(這不是比第一個(gè)方法還要簡(jiǎn)潔嗎!)
方法三:利用通配符
A="helloworld" B="low" if [[ $A == *$B* ]] then echo "包含" else echo "不包含" fi
這個(gè)也很easy,用通配符*號(hào)代理strA中非strB的部分,如果結(jié)果相等說(shuō)明包含,反之不包含。
方法四:利用case in 語(yǔ)句
thisString="1 2 3 4 5" # 源字符串 searchString="1 2" # 搜索字符串 case $thisString in *"$searchString"*) echo Enemy Spot ;; *) echo nope ;; esa
這個(gè)就比較復(fù)雜了,case in 我還沒(méi)有接觸到,不過(guò)既然有比較簡(jiǎn)單的方法何必如此
方法五:利用替換
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
這個(gè)也挺復(fù)雜
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
標(biāo)簽:滁州 百色 優(yōu)質(zhì)小號(hào) 自貢 丹東 六盤(pán)水 鎮(zhèn)江 武漢
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《用Shell判斷字符串包含關(guān)系的方法小結(jié)》,本文關(guān)鍵詞 用,Shell,判斷,字符串,包含,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。