欧美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開(kāi)始的n2個(gè)字符,組成一個(gè)子字符串??梢愿鶕?jù)特定字符偏移和長(zhǎng)度,使用另一種形式的變量擴(kuò)展,來(lái)選擇特定子字符串。試著在 bash 中輸入以下行:

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

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

3.按照指定要求分割:

比如獲取后綴名

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

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

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

一、判斷讀取字符串值

表達(dá)式 含義

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

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

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

表達(dá)式 含義

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

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

 實(shí)例:

讀取:

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

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開(kāi)始的   
str="abc"  
expr index $str "a"  # 1  
expr index $str "b"  # 2  
expr index $str "x"  # 0  
expr index $str ""   # 0   

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

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

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

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

4,字符串截取

echo ${string:4}      //2342341  從第4位開(kāi)始截取后面所有字符串    
echo ${string:3:3}    //123      從第3位開(kāi)始截取后面3位    
echo ${string:3:6}    //123423   從第3位開(kāi)始截取后面6位    
echo ${string: -4}    //2341  :右邊有空格   截取后4位    
echo ${string:(-4)}   //2341  同上    
expr substr $string 3 3   //123  從第3位開(kāi)始截取后面3位    
str="abcdef"  
expr substr "$str" 1 3  # 從第一個(gè)位置開(kāi)始取3個(gè)字符, abc  
expr substr "$str" 2 5  # 從第二個(gè)位置開(kāi)始取5個(gè)字符, bcdef   
expr substr "$str" 4 5  # 從第四個(gè)位置開(kāi)始取5個(gè)字符, def  
  
echo ${str:2}           # 從第二個(gè)位置開(kāi)始提取字符串, bcdef  
echo ${str:2:3}         # 從第二個(gè)位置開(kāi)始提取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左邊開(kāi)始,去掉最短匹配子串    
echo ${string#c*3}     //abc12342341  這樣什么也沒(méi)有匹配到    
echo ${string#*c1*3}   //42341  從$string左邊開(kāi)始,去掉最短匹配子串    
echo ${string##a*3}    //41     從$string左邊開(kāi)始,去掉最長(zhǎng)匹配子串    
echo ${string%3*1}     //abc12342  從$string右邊開(kāi)始,去掉最短匹配子串    
echo ${string%%3*1}    //abc12     從$string右邊開(kāi)始,去掉最長(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中沒(méi)有"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è)字符開(kāi)始,或者從最后一個(gè)開(kāi)始,可以這樣記憶, 井號(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   #以什么開(kāi)頭來(lái)匹配,根php中的^有點(diǎn)像    
echo ${string/%41/bb}  //abc123423bb  %以什么結(jié)尾來(lái)匹配,根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開(kāi)頭,則用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á)式}從字符串開(kāi)頭開(kāi)始配備substring,刪除匹配上的表達(dá)式。 
#${變量名%substring正則表達(dá)式}從字符串結(jié)尾開(kāi)始配備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)文章

  • linux批量備份服務(wù)器配置文件和目錄的腳本

    linux批量備份服務(wù)器配置文件和目錄的腳本

    這篇文章主要介紹了linux下批量備份服務(wù)器配置文件和目錄的方法,需要的朋友可以參考下
    2013-08-08
  • shell腳本批量刪除es索引的方法

    shell腳本批量刪除es索引的方法

    今天小編就為大家分享一篇關(guān)于shell腳本批量刪除es索引的方法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03
  • 數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸

    數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸

    這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • shell腳本字符串處理的使用(分割、截取和拼接)

    shell腳本字符串處理的使用(分割、截取和拼接)

    本文主要介紹了shell腳本字符串處理的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • touch shell腳本并修改為777權(quán)限的方法

    touch shell腳本并修改為777權(quán)限的方法

    這篇文章主要介紹了touch shell腳本并修改為777權(quán)限的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Linux Shell腳本系列教程(六):數(shù)組和關(guān)聯(lián)數(shù)組

    Linux Shell腳本系列教程(六):數(shù)組和關(guān)聯(lián)數(shù)組

    這篇文章主要介紹了Linux Shell腳本系列教程(六):數(shù)組和關(guān)聯(lián)數(shù)組,本文講解了什么是數(shù)組和關(guān)聯(lián)數(shù)組、定義打印普通數(shù)組、定義打印關(guān)聯(lián)數(shù)組等內(nèi)容,需要的朋友可以參考下
    2015-06-06
  • linux shell腳本學(xué)習(xí)xargs命令使用詳解

    linux shell腳本學(xué)習(xí)xargs命令使用詳解

    xargs是一條Unix和類Unix操作系統(tǒng)的常用命令。它的作用是將參數(shù)列表轉(zhuǎn)換成小塊分段傳遞給其他命令,以避免參數(shù)列表過(guò)長(zhǎng)的問(wèn)題
    2013-12-12
  • 詳解NC反彈shell的幾種方法

    詳解NC反彈shell的幾種方法

    這篇文章主要介紹了詳解NC反彈shell的幾種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • Shell實(shí)現(xiàn)文本去重并操持原有順序

    Shell實(shí)現(xiàn)文本去重并操持原有順序

    這篇文章主要介紹了Shell實(shí)現(xiàn)文本去重并操持原有順序,本文分步驟講解如何解決需求,并給出了若干方法,需要的朋友可以參考下
    2015-03-03
  • 學(xué)習(xí)shell腳本之前的基礎(chǔ)知識(shí)[圖文]

    學(xué)習(xí)shell腳本之前的基礎(chǔ)知識(shí)[圖文]

    在學(xué)習(xí)shell腳本之前,需要你了解很多關(guān)于shell的知識(shí),這些知識(shí)是編寫shell腳本的基礎(chǔ),所以希望你能夠熟練的掌握
    2013-03-03

最新評(píng)論