溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Bash Shell字符串操作方法介紹

發(fā)布時(shí)間:2021-07-28 17:07:57 來源:億速云 閱讀:116 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Bash Shell字符串操作方法介紹”,在日常操作中,相信很多人在Bash Shell字符串操作方法介紹問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Bash Shell字符串操作方法介紹”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

1. 取長度

代碼如下:

str="abcd"
expr length $str   # 4
echo ${#str}       # 4
expr "$str" : ".*" # 4


好像一般使用第二種
2. 查找子串的位置

代碼如下:

str="abc"
expr index $str "a"  # 1
expr index $str "b"  # 2
expr index $str "x"  # 0
expr index $str ""   # 0


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


4. 截取子串

代碼如下:

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)(##) 表示從左邊截取掉最長的匹配 (這里把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)表示(%%)表示從右邊截取最長的匹配
echo ${str%a*c}     # abbc,def,ghi,abcjkl
可以這樣記憶, 井號(hào)(#)通常用于表示一個(gè)數(shù)字,它是放在前面的;百分號(hào)(%)卸載數(shù)字的后面; 或者這樣記憶,在鍵盤布局中,井號(hào)(#)總是位于百分號(hào)(%)的左邊(即前面) 


5. 字符串替換

代碼如下:

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替換它


6. 比較

代碼如下:

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


7. 連接

代碼如下:

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

8.將一批文件中的所有string替換

代碼如下:

for i in file_list
do
vi $i <<-!
:g/xxxx/s//XXXX/g
:wq
!
done

9.翻轉(zhuǎn)

方法一:
使用rev命令

方法二:
編寫腳本實(shí)現(xiàn)

代碼如下:

#!/usr/bin/awk -f
################################################################
# Description : duplicate rev in awk
################################################################
{
revline = ""
for (i=1;i<=length;i++)
{
revline = substr(,i,1) revline
}
}
END{print revline}


10.匹配

代碼如下:

grep
egrep
fgrep

11.得到字符串中某個(gè)字符的重復(fù)次數(shù)

代碼如下:

echo $a |tr "x" "\n" |wc -l


得到的結(jié)果需要減去1
或者

代碼如下:

echo $a |awk -F"x" '{print NF-1}'


12.如何將字符串內(nèi)每兩個(gè)字符中間插入一個(gè)字符
使用sed

代碼如下:

echo $test |sed 's/../&[insert char]/g'

到此,關(guān)于“Bash Shell字符串操作方法介紹”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI