国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Linux Shell > 正文

Bash Shell字符串操作小結

2020-07-27 19:16:40
字體:
來源:轉載
供稿:網友

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  # 從第一個位置開始取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}        # 從倒數第二個位置向左提取字符串, abcde
echo ${str:(-4):3}      # 從倒數第二個位置向左提取6個字符, cde

4. 截取子串
復制代碼 代碼如下:
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
可以這樣記憶, 井號(#)通常用于表示一個數字,它是放在前面的;百分號(%)卸載數字的后面; 或者這樣記憶,在鍵盤布局中,井號(#)總是位于百分號(%)的左邊(即前面) 

5. 字符串替換
復制代碼 代碼如下:
str="apple, tree, apple tree"
echo ${str/apple/APPLE}   # 替換第一次出現的apple
echo ${str//apple/APPLE}  # 替換所有apple
echo ${str/#apple/APPLE}  # 如果字符串str以apple開頭,則用APPLE替換它
echo ${str/%apple/APPLE}  # 如果字符串str以apple結尾,則用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}   # 當然這樣寫 $s1$s2 也行,但最好加上大括號

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

復制代碼 代碼如下:
for i in file_list
do
vi $i <<-!
:g/xxxx/s//XXXX/g
:wq
!
done

9.翻轉

方法一:
使用rev命令

方法二:
編寫腳本實現

復制代碼 代碼如下:
#!/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.得到字符串中某個字符的重復次數

復制代碼 代碼如下:
echo $a |tr "x" "/n" |wc -l

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


12.如何將字符串內每兩個字符中間插入一個字符
使用sed

復制代碼 代碼如下:
echo $test |sed 's/../&[insert char]/g'

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 紫阳县| 昂仁县| 吴川市| 全南县| 洛浦县| 出国| 绥德县| 五大连池市| 图们市| 东海县| 辽源市| 青州市| 横峰县| 本溪市| 安国市| 出国| 禹州市| 察哈| 定远县| 红安县| 横山县| 河曲县| 高邮市| 盐城市| 闽清县| 襄城县| 乐昌市| 南部县| 青州市| 乌海市| 汶川县| 宁海县| 汉中市| 湘阴县| 株洲县| 通江县| 铜山县| 遂昌县| 监利县| 凤阳县| 洛隆县|