linux?shell字符串截取的詳細(xì)總結(jié)(實(shí)用!)
一、字符串變量的截取操作
對(duì)字符串變量的截取操作一般都是通過${操作符}的方式進(jìn)行,如下:
1.從指定位置(index)截取固定長(zhǎng)度
格式:${string:start:length}
其中,string 是要截取的字符串,start 是起始位置(下標(biāo)從 0 開始計(jì)數(shù)),length 是要截取的長(zhǎng)度(省略的話表示直到字符串的末尾)
例如:
str_time='2022-02-01 12:30:58' date_no=${str_time:0:10}? ? ? ? ? #截取前面10位字符:2022-01-01 date_mon=${str_time:5:2}? ? ? ? ?#從前面第6位開始截取2位字符:02 date_time=${str_time:0-8}? ? ? ? ?#截取后面8位字符:12:30:58 date_hh=${str_time:0-8:2}? ? ? ? ?#截取后面8位字符的前面兩位:12
2.截取指定字符串(子字符串)左邊的字符
格式1:${string%substr*} #匹配從右往左第一個(gè)substr
格式2:${string%%substr*} #匹配從右往左最后一個(gè)substr
說明:上面%的運(yùn)算實(shí)際上可以理解為,刪除substr以及substr右邊的任意字符串,*號(hào)在substr右邊,從而得到substr左邊剩余字符串。 格式1和格式2的區(qū)別是匹配substr的位置
例如:
v_str='/app/logs/133.38.112.177_202204111015.log' echo ${v_str%/*}? ? ? ? ? ? ? #截取從右往左第一個(gè)'/' 左邊的字符:/app/logs echo ${v_str%%/*}? ? ? ? ? ?#截取從右往左最后個(gè)'/' 左邊的字符:空
3.截取指定字符串(子字符串)右邊的字符
格式1:${string#*substr} #匹配從左往右第一個(gè)substr
格式2:${string##*substr} #匹配從左往右最后一個(gè)substr
說明:上面'#'的運(yùn)算實(shí)際上可以理解為,刪除substr以及substr左邊的任意字符串,*號(hào)在substr的左邊,從而得到substr右邊剩余字符串。 格式1和格式2的區(qū)別是匹配substr的位置
例如:
v_str='/app/logs/133.38.112.177_202204111015.log' #截取從左往右第一個(gè)'/' 右邊的字符:app/logs/133.38.112.177_202204111015.log echo ${v_str#*/} #截取從左往右最后個(gè)'/' 右邊的字符:133.38.112.177_202204111015.log echo ${v_str##*/}
注意:用%和#截取字符串的用法,比較容易忘記容易混淆。
有個(gè)小技巧加以區(qū)別:
鍵盤上#號(hào)在$符號(hào)的左邊,所以是操作并刪除左邊字符,所以*在substr左邊,一個(gè)#號(hào)代表取第一個(gè)substr(從左往右):${string#*substr}
鍵盤上%號(hào)在$符號(hào)的右邊,所以是操作并刪除右邊字符,所以*在substr的右邊,一個(gè)%代表取第一個(gè)substr(從右往左):${string%substr*}
二、用cut命令截?。ㄟm合處理管道流或行文本字符)
格式:cut OPTION... [FILE]
cut 命令從文件的每一行剪切字節(jié)、字符和字段并將這些字節(jié)、字符和字段寫至標(biāo)準(zhǔn)輸出。
如果不指定 File 參數(shù),cut 命令將讀取標(biāo)準(zhǔn)輸入。必須指定 -b、-c 或 -f 標(biāo)志之一。
OPTION:
- -b :以字節(jié)為單位選取指定的字節(jié)數(shù)
- -c :以字符為單位選取指定的字符數(shù)
- -d :指定分隔符(默認(rèn)是tab)將字符串分為多個(gè)區(qū)域,一般與-f參數(shù)一起使用
- -f :與-d一起使用,指定選取哪個(gè)區(qū)域
- -n :取消分割多字節(jié)字符。僅和 -b 標(biāo)志一起使用。如果字符的最后一個(gè)字節(jié)落在由 -b 標(biāo)志的 List 參數(shù)指示的范圍之內(nèi),該字符將被寫出;否則,該字符將被排除
用法:
例如:處理test.txt文件,截取每一行的指定字符
$?cat test.txt? a_202204110214_10.251.82.225 b_202204110215_10.251.82.223 b_202204110212_10.251.82.226 c_202204110214_10.251.82.228 -b選項(xiàng): $ cut -b 1,3 test.txt? ?#截取1,3字節(jié) a2 b2 b2 c2 $ cut -b 1-3 test.txt? ?#截取1到3字節(jié) a_2 b_2 b_2 c_2 -c選項(xiàng): $ cut -c 1,3 test.txt? ?#截取1,3字符 a2 b2 b2 c2 $ cut -c 1-3 test.txt? ?#截取1到3字符 a_2 b_2 b_2 c_2 -d -f選項(xiàng): $ cut -d'_' -f3 test.txt? ?#以下劃線分割,取第三個(gè)區(qū)域字符 10.251.82.225 10.251.82.223 10.251.82.226 10.251.82.228 $ cat test.txt | cut -d'_' -f3? ?#結(jié)合管道使用效果一樣
補(bǔ)充:使用%和%%:截取的是指定字符前邊內(nèi)容
val=“hello++world++shell” echo ${val%++*} # 刪除最后一個(gè) ++ 后邊字符,截取前邊剩下的內(nèi)容 # 輸出: hello++world echo ${val%%++*} # 刪除第一個(gè) ++ 后邊字符,只截取保留第一個(gè) ++ 前邊的內(nèi)容 # 輸出: hello?
示例 截取文件名字,去掉后綴
str_file="123.hello.json" echo ${str_file%.*} # 刪除最后一個(gè) . 后邊的json,截取123.hello # 輸出: 123.hello
總結(jié)
到此這篇關(guān)于linux shell字符串截取的文章就介紹到這了,更多相關(guān)linux shell字符串截取內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Linux shell實(shí)現(xiàn)HTTP服務(wù)示例代碼
這篇文章介紹的是如何實(shí)現(xiàn)一個(gè)可以調(diào)用shell腳本的HTTP服務(wù),本文給出了詳細(xì)的示例代碼,有需要的可以參考借鑒。2016-08-08一天一個(gè)shell命令 linux文件操作系列-ln命令詳解
這篇文章主要介紹了一天一個(gè)shell命令 linux文件操作系列-ln命令詳解 ,需要的朋友可以參考下2016-06-06Python執(zhí)行Linux系統(tǒng)命令的4種方法
這篇文章主要介紹了Python執(zhí)行Linux系統(tǒng)命令的4種方法,即在Python腳本中調(diào)用Shell命令,需要的朋友可以參考下2014-10-10Shell腳本中讓進(jìn)程休眠的方法(sleep用法)
這篇文章主要介紹了Shell腳本中讓進(jìn)程休眠的方法,本文講解的就是sleep的用法,可以實(shí)現(xiàn)睡覺若干秒、若干分鐘、若干小時(shí),需要的朋友可以參考下2014-11-11Shell腳本中執(zhí)行sql語句操作mysql的5種方法
這篇文章主要介紹了Shell腳本中執(zhí)行sql語句操作mysql的5種方法,本文講解了將SQL語句直接嵌入到shell腳本文件中、命令行調(diào)用單獨(dú)的SQL文件、使用管道符調(diào)用SQL文件等方法,需要的朋友可以參考下2014-10-10