Bash Shell字符串操作小結(jié)
更新時間:2014年05月27日 09:32:34 作者:
這篇文章主要介紹了Bash Shell字符串操作總結(jié),包含取長度、截取、查找位置、替換等等,需要的朋友可以參考下
1. 取長度
復(fù)制代碼 代碼如下:
str="abcd"
expr length $str # 4
echo ${#str} # 4
expr "$str" : ".*" # 4
expr length $str # 4
echo ${#str} # 4
expr "$str" : ".*" # 4
好像一般使用第二種
2. 查找子串的位置
復(fù)制代碼 代碼如下:
str="abc"
expr index $str "a" # 1
expr index $str "b" # 2
expr index $str "x" # 0
expr index $str "" # 0
expr index $str "a" # 1
expr index $str "b" # 2
expr index $str "x" # 0
expr index $str "" # 0
3. 選取子串
復(fù)制代碼 代碼如下:
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
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
4. 截取子串
復(fù)制代碼 代碼如下:
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ù)字的后面; 或者這樣記憶,在鍵盤布局中,井號(#)總是位于百分號(%)的左邊(即前面)
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ù)字的后面; 或者這樣記憶,在鍵盤布局中,井號(#)總是位于百分號(%)的左邊(即前面)
5. 字符串替換
復(fù)制代碼 代碼如下:
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替換它
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. 比較
復(fù)制代碼 代碼如下:
[[ "a.txt" == a* ]] # 邏輯真 (pattern matching)
[[ "a.txt" =~ .*\.txt ]] # 邏輯真 (regex matching)
[[ "abc" == "abc" ]] # 邏輯真 (string comparision)
[[ "11" < "2" ]] # 邏輯真 (string comparision), 按ascii值比較
[[ "a.txt" =~ .*\.txt ]] # 邏輯真 (regex matching)
[[ "abc" == "abc" ]] # 邏輯真 (string comparision)
[[ "11" < "2" ]] # 邏輯真 (string comparision), 按ascii值比較
7. 連接
復(fù)制代碼 代碼如下:
s1="hello"
s2="world"
echo ${s1}${s2} # 當(dāng)然這樣寫 $s1$s2 也行,但最好加上大括號
s2="world"
echo ${s1}${s2} # 當(dāng)然這樣寫 $s1$s2 也行,但最好加上大括號
8.將一批文件中的所有string替換
復(fù)制代碼 代碼如下:
for i in file_list
do
vi $i <<-!
:g/xxxx/s//XXXX/g
:wq
!
done
do
vi $i <<-!
:g/xxxx/s//XXXX/g
:wq
!
done
9.翻轉(zhuǎn)
方法一:
使用rev命令
方法二:
編寫腳本實現(xiàn)
復(fù)制代碼 代碼如下:
#!/usr/bin/awk -f
################################################################
# Description : duplicate rev in awk
################################################################
{
revline = ""
for (i=1;i<=length;i++)
{
revline = substr(,i,1) revline
}
}
END{print revline}
################################################################
# Description : duplicate rev in awk
################################################################
{
revline = ""
for (i=1;i<=length;i++)
{
revline = substr(,i,1) revline
}
}
END{print revline}
10.匹配
復(fù)制代碼 代碼如下:
grep
egrep
fgrep
egrep
fgrep
11.得到字符串中某個字符的重復(fù)次數(shù)
復(fù)制代碼 代碼如下:
echo $a |tr "x" "\n" |wc -l
得到的結(jié)果需要減去1
或者
復(fù)制代碼 代碼如下:
echo $a |awk -F"x" '{print NF-1}'
12.如何將字符串內(nèi)每兩個字符中間插入一個字符
使用sed
復(fù)制代碼 代碼如下:
echo $test |sed 's/../&[insert char]/g'
相關(guān)文章
Shell腳本調(diào)快調(diào)慢系統(tǒng)時間(測試服務(wù)器時使用)
這篇文章主要介紹了Shell腳本修改系統(tǒng)時間(測試服務(wù)器時使用),本文腳本用于調(diào)快或者調(diào)慢系統(tǒng)時間,需要的朋友可以參考下2014-12-12ubuntu使用root用戶登錄/切換root權(quán)限的實現(xiàn)
下面小編就為大家?guī)硪黄猽buntu使用root用戶登錄/切換root權(quán)限的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01Shell腳本實現(xiàn)檢測Cygwin最快的鏡像站點
這篇文章主要介紹了Shell腳本實現(xiàn)檢測Cygwin最快的鏡像站點,本文的原理和腳本也可適用其它軟件比如apache、nginx等開源軟件,需要的朋友可以參考下2015-04-04Linux shell傳遞參數(shù)實現(xiàn)原理及代碼實例
這篇文章主要介紹了Linux shell傳遞參數(shù)實現(xiàn)原理及代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08解決linux?shell中傳遞包含空格的參數(shù)問題
這篇文章主要介紹了如何解決linux?shell中傳遞包含空格的參數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09