Bash Shell字符串操作

這篇文章主要介紹了Bash Shell字符串操作總結(jié),包含取長度、截取、查找位置、替換等等,需要的朋友可以參考下

  1. 取長度
    代碼如下:
    str="abcd"
    expr length $str # 4
    echo ${#str} # 4
    expr "$str" : ".*" # 4

好像一般使用第二種

  1. 查找子串的位置
    代碼如下:
    str="abc"
    expr index $str "a" # 1
    expr index $str "b" # 2
    expr index $str "x" # 0
    expr index $str "" # 0

  2. 選取子串
    代碼如下:
    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

  3. 截取子串
    代碼如下:
    str="abbc,def,ghi,abcjkl"
    echo ${str#ac} # 輸出,def,ghi,abcjkl 一個井號(#) 表示從左邊截取掉最短的匹配 (這里把a(bǔ)bbc字串去掉)
    echo ${str##a
    c} # 輸出jkl, 兩個井號(##) 表示從左邊截取掉最長的匹配 (這里把a(bǔ)bbc,def,ghi,abc字串去掉)
    echo ${str#"ac"} # 輸出abbc,def,ghi,abcjkl 因?yàn)閟tr中沒有"ac"子串
    echo ${str##"ac"} # 輸出abbc,def,ghi,abcjkl 同理
    echo ${str#
    ac} # 空
    echo ${str##ac} # 空
    echo ${str#d
    f) # 輸出abbc,def,ghi,abcjkl,
    echo ${str#df} # 輸出,ghi,abcjkl
    echo ${str%al} # abbc,def,ghi 一個百分號(%)表示從右邊截取最短的匹配
    echo ${str%%b
    l} # a 兩個百分號表示(%%)表示從右邊截取最長的匹配
    echo ${str%a*c} # abbc,def,ghi,abcjkl
    可以這樣記憶, 井號(#)通常用于表示一個數(shù)字,它是放在前面的;百分號(%)卸載數(shù)字的后面; 或者這樣記憶,在鍵盤布局中,井號(#)總是位于百分號(%)的左邊(即前面)

  4. 字符串替換
    代碼如下:
    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替換它

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

  6. 連接
    代碼如下:
    s1="hello"
    s2="world"
    echo ${s1}${s2} # 當(dāng)然這樣寫 $s1$s2 也行,但最好加上大括號
    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.得到字符串中某個字符的重復(fù)次數(shù)
代碼如下:
echo $a |tr "x" "\n" |wc -l

得到的結(jié)果需要減去1
或者
代碼如下:
echo $a |awk -F"x" '{print NF-1}'

12.如何將字符串內(nèi)每兩個字符中間插入一個字符
使用sed
代碼如下:
echo $test |sed 's/../&[insert char]/g'

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容