欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

linux?shell字符串操作詳解(長(zhǎng)度、讀取、替換、截取、連接、對(duì)比、刪除及位置)

 更新時(shí)間:2024年03月01日 11:56:49   作者:gaomatlab  
字符串是shell編程中最常用最有用的數(shù)據(jù)類型,這篇文章主要給大家介紹了關(guān)于linux?shell字符串操作(長(zhǎng)度、讀取、替換、截取、連接、對(duì)比、刪除及位置)的相關(guān)資料,需要的朋友可以參考下

1.Linux shell 截取字符變量的前8位

實(shí)現(xiàn)方法有如下幾種:

  • expr substr “$a” 1 8
  • echo $a|awk ‘{print substr(,1,8)}’
  • echo $a|cut -c1-8
  • echo $
  • expr $a : ‘\(.\\).*’
  • echo $a|dd bs=1 count=8 2>/dev/null

2.按指定的字符串截取

(1)第一種方法:

從左向右截取最后一個(gè)string后的字符串

  • ${varible##*string}

從左向右截取第一個(gè)string后的字符串

  • ${varible#*string}

從右向左截取最后一個(gè)string后的字符串

  • ${varible%%string*}

從右向左截取第一個(gè)string后的字符串

  • ${varible%string*}

“*”只是一個(gè)通配符可以不要

請(qǐng)看下面的例子:

$ MYVAR=foodforthought.jpg
$ echo ${MYVAR##*fo}
rthought.jpg
$ echo ${MYVAR#*fo}
odforthought.jpg

(2)第二種方法:

${varible:n1:n2}:截取變量varible從n1開始的n2個(gè)字符,組成一個(gè)子字符串??梢愿鶕?jù)特定字符偏移和長(zhǎng)度,使用另一種形式的變量擴(kuò)展,來選擇特定子字符串。試著在 bash 中輸入以下行:

$ EXCLAIM=cowabunga
$ echo ${EXCLAIM:0:3}
cow
$ echo ${EXCLAIM:3:7}
abunga

這種形式的字符串截?cái)喾浅:?jiǎn)便,只需用冒號(hào)分開來指定起始字符和子字符串長(zhǎng)度。

3.按照指定要求分割:

比如獲取后綴名

ls -al | cut -d “.” -f2

小結(jié):shell對(duì)應(yīng)字符串的處理方法很多,根據(jù)需求靈活選擇。

在做shell批處理程序時(shí)候,經(jīng)常會(huì)涉及到字符串相關(guān)操作。有很多命令語句,如:awk,sed都可以做字符串各種操作。 其實(shí)shell內(nèi)置一系列操作符號(hào),可以達(dá)到類似效果,大家知道,使用內(nèi)部操作符會(huì)省略啟動(dòng)外部程序等時(shí)間,因此速度會(huì)非常的快。

一、判斷讀取字符串值

表達(dá)式 含義

${var}變量var的值, 與$var相同
${var-DEFAULT}如果var沒有被聲明, 那么就以$DEFAULT作為其值 *
${var:-DEFAULT}如果var沒有被聲明, 或者其值為空, 那么就以$DEFAULT作為其值 *
${var=DEFAULT}如果var沒有被聲明, 那么就以$DEFAULT作為其值 *
${var:=DEFAULT}如果var沒有被聲明, 或者其值為空, 那么就以$DEFAULT作為其值 *
${var+OTHER}如果var聲明了, 那么其值就是$OTHER, 否則就為null字符串
${var:+OTHER}如果var被設(shè)置了, 那么其值就是$OTHER, 否則就為null字符串
${var?ERR_MSG}如果var沒被聲明, 那么就打印$ERR_MSG *
${var:?ERR_MSG}如果var沒被設(shè)置, 那么就打印$ERR_MSG *
${!varprefix*}匹配之前所有以varprefix開頭進(jìn)行聲明的變量
${!varprefix@}匹配之前所有以varprefix開頭進(jìn)行聲明的變量

加入了“*”  不是意思是: 當(dāng)然, 如果變量var已經(jīng)被設(shè)置的話, 那么其值就是$var.

二、字符串操作(長(zhǎng)度,讀取,替換)

表達(dá)式 含義

${#string}$string的長(zhǎng)度
${string:position}在$string中, 從位置$position開始提取子串
${string:position:length}在$string中, 從位置$position開始提取長(zhǎng)度為$length的子串
${string#substring}從變量$string的開頭, 刪除最短匹配$substring的子串
${string##substring}從變量$string的開頭, 刪除最長(zhǎng)匹配$substring的子串
${string%substring}從變量$string的結(jié)尾, 刪除最短匹配$substring的子串
${string%%substring}從變量$string的結(jié)尾, 刪除最長(zhǎng)匹配$substring的子串
${string/substring/replacement}使用$replacement, 來代替第一個(gè)匹配的$substring
${string//substring/replacement}使用$replacement, 代替所有匹配的$substring
${string/#substring/replacement}如果$string的前綴匹配$substring, 那么就用$replacement來代替匹配到的$substring
${string/%substring/replacement}如果$string的后綴匹配$substring, 那么就用$replacement來代替匹配到的$substring

說明:"* $substring”可以是一個(gè)正則表達(dá)式.

 實(shí)例:

讀取:

$ echo ${abc-'ok'}  
ok  
$ echo $abc  
$ echo ${abc='ok'}  
ok  
$ echo $abc  
ok  
#如果abc 沒有聲明“=" 還會(huì)給abc賦值。  
$ var1=11;var2=12;var3=  
$ echo ${!v@}             
var1 var2 var3  
$ echo ${!v*}  
var1 var2 var3  
#${!varprefix*}與${!varprefix@}相似,可以通過變量名前綴字符,搜索已經(jīng)定義的變量,無論是否為空值。

1,取得字符串長(zhǎng)度

string=abc12342341          //等號(hào)二邊不要有空格  
echo ${#string}             //結(jié)果11  
expr length $string         //結(jié)果11  
expr "$string" : ".*"       //結(jié)果11 分號(hào)二邊要有空格,這里的:根match的用法差不多  

2,字符串所在位置

expr index $string '123'    //結(jié)果4 字符串對(duì)應(yīng)的下標(biāo)是從1開始的   
str="abc"  
expr index $str "a"  # 1  
expr index $str "b"  # 2  
expr index $str "x"  # 0  
expr index $str ""   # 0   

這個(gè)方法讓我想起來了js的indexOf,各種語言對(duì)字符串的操作方法大方向都差不多,如果有語言基礎(chǔ)的話,學(xué)習(xí)shell會(huì)很快的。

3,從字符串開頭到子串的最大長(zhǎng)度

expr match $string 'abc.*3' //結(jié)果9    

個(gè)人覺得這個(gè)函數(shù)的用處不大,為什么要從開頭開始呢。

4,字符串截取

echo ${string:4}      //2342341  從第4位開始截取后面所有字符串    
echo ${string:3:3}    //123      從第3位開始截取后面3位    
echo ${string:3:6}    //123423   從第3位開始截取后面6位    
echo ${string: -4}    //2341  :右邊有空格   截取后4位    
echo ${string:(-4)}   //2341  同上    
expr substr $string 3 3   //123  從第3位開始截取后面3位    
str="abcdef"  
expr substr "$str" 1 3  # 從第一個(gè)位置開始取3個(gè)字符, abc  
expr substr "$str" 2 5  # 從第二個(gè)位置開始取5個(gè)字符, bcdef   
expr substr "$str" 4 5  # 從第四個(gè)位置開始取5個(gè)字符, def  
  
echo ${str:2}           # 從第二個(gè)位置開始提取字符串, bcdef  
echo ${str:2:3}         # 從第二個(gè)位置開始提取3個(gè)字符, bcd  
echo ${str:(-6):5}        # 從倒數(shù)第二個(gè)位置向左提取字符串, abcde  
echo ${str:(-4):3}      # 從倒數(shù)第二個(gè)位置向左提取6個(gè)字符, cde  

上面的方法讓我想起了,php的substr函數(shù),后面截取的規(guī)則是一樣的。

5,匹配顯示內(nèi)容

//例3中也有match和這里的match不同,上面顯示的是匹配字符的長(zhǎng)度,而下面的是匹配的內(nèi)容    
expr match $string '\([a-c]*[0-9]*\)'  //abc12342341    
expr $string : '\([a-c]*[0-9]\)'       //abc1    
expr $string : '.*\([0-9][0-9][0-9]\)' //341 顯示括號(hào)中匹配的內(nèi)容    

這里括號(hào)的用法,是不是根其他的括號(hào)用法有相似之處呢,

6,截取不匹配的內(nèi)容

echo ${string#a*3}     //42341  從$string左邊開始,去掉最短匹配子串    
echo ${string#c*3}     //abc12342341  這樣什么也沒有匹配到    
echo ${string#*c1*3}   //42341  從$string左邊開始,去掉最短匹配子串    
echo ${string##a*3}    //41     從$string左邊開始,去掉最長(zhǎng)匹配子串    
echo ${string%3*1}     //abc12342  從$string右邊開始,去掉最短匹配子串    
echo ${string%%3*1}    //abc12     從$string右邊開始,去掉最長(zhǎng)匹配子串    
str="abbc,def,ghi,abcjkl"  
echo ${str#a*c}     # 輸出,def,ghi,abcjkl  一個(gè)井號(hào)(#) 表示從左邊截取掉最短的匹配 (這里把a(bǔ)bbc字串去掉)  
echo ${str##a*c}    # 輸出jkl,             兩個(gè)井號(hào)(##) 表示從左邊截取掉最長(zhǎng)的匹配 (這里把a(bǔ)bbc,def,ghi,abc字串去掉)  
echo ${str#"a*c"}   # 輸出abbc,def,ghi,abcjkl 因?yàn)閟tr中沒有"a*c"子串  
echo ${str##"a*c"}  # 輸出abbc,def,ghi,abcjkl 同理  
echo ${str#*a*c*}   # 空  
echo ${str##*a*c*}  # 空  
echo ${str#d*f)     # 輸出abbc,def,ghi,abcjkl,   
echo ${str#*d*f}    # 輸出,ghi,abcjkl     
  
echo ${str%a*l}     # abbc,def,ghi  一個(gè)百分號(hào)(%)表示從右邊截取最短的匹配   
echo ${str%%b*l}    # a             兩個(gè)百分號(hào)表示(%%)表示從右邊截取最長(zhǎng)的匹配  
echo ${str%a*c}     # abbc,def,ghi,abcjkl    

這里要注意,必須從字符串的第一個(gè)字符開始,或者從最后一個(gè)開始,可以這樣記憶, 井號(hào)(#)通常用于表示一個(gè)數(shù)字,它是放在前面的;百分號(hào)(%)卸載數(shù)字的后面; 或者這樣記憶,在鍵盤布局中,井號(hào)(#)總是位于百分號(hào)(%)的左邊(即前面)  。

7,匹配并且替換

echo ${string/23/bb}   //abc1bb42341  替換一次    
echo ${string//23/bb}  //abc1bb4bb41  雙斜杠替換所有匹配    
echo ${string/#abc/bb} //bb12342341   #以什么開頭來匹配,根php中的^有點(diǎn)像    
echo ${string/%41/bb}  //abc123423bb  %以什么結(jié)尾來匹配,根php中的$有點(diǎn)像   
str="apple, tree, apple tree"  
echo ${str/apple/APPLE}   # 替換第一次出現(xiàn)的apple  
echo ${str//apple/APPLE}  # 替換所有apple  
  
echo ${str/#apple/APPLE}  # 如果字符串str以apple開頭,則用APPLE替換它  
echo ${str/%apple/APPLE}  # 如果字符串str以apple結(jié)尾,則用APPLE替換它  
$ test='c:/windows/boot.ini'  
$ echo ${test/\//\\}  
c:\windows/boot.ini  
$ echo ${test//\//\\}  
c:\windows\boot.ini  
  
#${變量/查找/替換值} 一個(gè)“/”表示替換第一個(gè),”//”表示替換所有,當(dāng)查找中出現(xiàn)了:”/”請(qǐng)加轉(zhuǎn)義符”\/”表示。  

8. 比較

[[ "a.txt" == a* ]]        # 邏輯真 (pattern matching)  
[[ "a.txt" =~ .*\.txt ]]   # 邏輯真 (regex matching)  
[[ "abc" == "abc" ]]       # 邏輯真 (string comparision)   
[[ "11" < "2" ]]           # 邏輯真 (string comparision), 按ascii值比較  

9. 連接

s1="hello"  
s2="world"  
echo ${s1}${s2}   # 當(dāng)然這樣寫 $s1$s2 也行,但最好加上大括號(hào)  

10. 字符串刪除

$ test='c:/windows/boot.ini'  
$ echo ${test#/}  
c:/windows/boot.ini  
$ echo ${test#*/}  
windows/boot.ini  
$ echo ${test##*/}  
boot.ini  
  
$ echo ${test%/*} 
c:/windows 
$ echo ${test%%/*} 

#${變量名#substring正則表達(dá)式}從字符串開頭開始配備substring,刪除匹配上的表達(dá)式。 
#${變量名%substring正則表達(dá)式}從字符串結(jié)尾開始配備substring,刪除匹配上的表達(dá)式。 
#注意:${test##*/},${test%/*} 分別是得到文件名,或者目錄地址最簡(jiǎn)單方法。   

總結(jié)

到此這篇關(guān)于linux shell字符串操作(長(zhǎng)度、讀取、替換、截取、連接、對(duì)比、刪除及位置)的文章就介紹到這了,更多相關(guān)linux shell字符串操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論