亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

實現(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)第一種方法:

從左向右截取最后一個string后的字符串

  • ${varible##*string}

從左向右截取第一個string后的字符串

  • ${varible#*string}

從右向左截取最后一個string后的字符串

  • ${varible%%string*}

從右向左截取第一個string后的字符串

  • ${varible%string*}

“*”只是一個通配符可以不要

請看下面的例子:

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

(2)第二種方法:

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

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

這種形式的字符串截斷非常簡便,只需用冒號分開來指定起始字符和子字符串長度。

3.按照指定要求分割:

比如獲取后綴名

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

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

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

一、判斷讀取字符串值

表達式 含義

${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開頭進行聲明的變量
${!varprefix@}匹配之前所有以varprefix開頭進行聲明的變量

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

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

表達式 含義

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

說明:"* $substring”可以是一個正則表達式.

 實例:

讀?。?/strong>

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

1,取得字符串長度

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

2,字符串所在位置

expr index $string '123'    //結(jié)果4 字符串對應(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   

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

3,從字符串開頭到子串的最大長度

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

個人覺得這個函數(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  # 從第一個位置開始取3個字符, abc  
expr substr "$str" 2 5  # 從第二個位置開始取5個字符, bcdef   
expr substr "$str" 4 5  # 從第四個位置開始取5個字符, def  
  
echo ${str:2}           # 從第二個位置開始提取字符串, bcdef  
echo ${str:2:3}         # 從第二個位置開始提取3個字符, bcd  
echo ${str:(-6):5}        # 從倒數(shù)第二個位置向左提取字符串, abcde  
echo ${str:(-4):3}      # 從倒數(shù)第二個位置向左提取6個字符, cde  

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

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

//例3中也有match和這里的match不同,上面顯示的是匹配字符的長度,而下面的是匹配的內(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 顯示括號中匹配的內(nèi)容    

這里括號的用法,是不是根其他的括號用法有相似之處呢,

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左邊開始,去掉最長匹配子串    
echo ${string%3*1}     //abc12342  從$string右邊開始,去掉最短匹配子串    
echo ${string%%3*1}    //abc12     從$string右邊開始,去掉最長匹配子串    
str="abbc,def,ghi,abcjkl"  
echo ${str#a*c}     # 輸出,def,ghi,abcjkl  一個井號(#) 表示從左邊截取掉最短的匹配 (這里把abbc字串去掉)  
echo ${str##a*c}    # 輸出jkl,             兩個井號(##) 表示從左邊截取掉最長的匹配 (這里把abbc,def,ghi,abc字串去掉)  
echo ${str#"a*c"}   # 輸出abbc,def,ghi,abcjkl 因為str中沒有"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  一個百分號(%)表示從右邊截取最短的匹配   
echo ${str%%b*l}    # a             兩個百分號表示(%%)表示從右邊截取最長的匹配  
echo ${str%a*c}     # abbc,def,ghi,abcjkl    

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

7,匹配并且替換

echo ${string/23/bb}   //abc1bb42341  替換一次    
echo ${string//23/bb}  //abc1bb4bb41  雙斜杠替換所有匹配    
echo ${string/#abc/bb} //bb12342341   #以什么開頭來匹配,根php中的^有點像    
echo ${string/%41/bb}  //abc123423bb  %以什么結(jié)尾來匹配,根php中的$有點像   
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  
  
#${變量/查找/替換值} 一個“/”表示替換第一個,”//”表示替換所有,當(dāng)查找中出現(xiàn)了:”/”請加轉(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 也行,但最好加上大括號  

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

總結(jié)

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

相關(guān)文章

最新評論