• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            大龍的博客

            常用鏈接

            統(tǒng)計

            最新評論

            shell中字符串處理方式

            象專業(yè)人員那樣截斷字符串
            盡管 basename 和 dirname 是很好的工具,但有時可能需要執(zhí)行更高級的字符串“截斷”,而不只是標準的路徑名操作。當需要更強的說服力時,可以利用 bash 內(nèi)置的變量擴展功能。已經(jīng)使用了類似于 ${MYVAR} 的標準類型的變量擴展。但是 bash 自身也可以執(zhí)行一些便利的字符串截斷。看一下這些例子:

            第一種方法:

            ${varible##*string} 從左向右截取最后一個string后的字符串

            ${varible#*string}從左向右截取第一個string后的字符串

            ${varible%%string*}從右向左截取最后一個string后的字符串

            ${varible%string*}從右向左截取第一個string后的字符串

            "*"只是一個通配符可以不要
            $ MYVAR=foodforthought.jpg
            $ echo ${MYVAR##*fo}
            rthought.jpg
            $ echo ${MYVAR#*fo}
            odforthought.jpg
            在 第一個例子中,輸入了 ${MYVAR##*fo}。它的確切含義是什么?基本上,在 ${ } 中輸入環(huán)境變量名稱,兩個 ##,然后是通配符 ("*fo")。然后,bash 取得 MYVAR,找到從字符串 "foodforthought.jpg" 開始處開始、且匹配通配符 "*fo" 的 最長 子字符串,然后將其從字符串的開始處截去。剛開始理解時會有些困難,為了感受一下這個特殊的 "##" 選項如何工作,讓我們一步步地看看 bash 如何完成這個擴展。首先,它從 "foodforthought.jpg" 的開始處搜索與 "*fo" 通配符匹配的子字符串。以下是檢查到的子字符串:   
            fo      MATCHES *fo
            foo
            food
            foodf      
            foodfo      MATCHES *fo
            foodfor
            foodfort   
            foodforth
            foodfortho  
            foodforthou
            foodforthoug
            foodforthought
            foodforthought.j
            foodforthought.jp
            foodforthought.jpg
            在搜索了匹配的字符串之后,可以看到 bash 找到兩個匹配。它選擇最長的匹配,從初始字符串的開始處除去,然后返回結果。

            上 面所示的第二個變量擴展形式看起來與第一個相同,但是它只使用一個 "#" -- 并且 bash 執(zhí)行 幾乎同樣的過程。它查看與第一個例子相同的子字符串系列,但是 bash 從初始字符串除去 最短 的匹配,然后返回結果。所以,一查到 "fo" 子字符串,它就從字符串中除去 "fo",然后返回 "odforthought.jpg"。

            這樣說可能會令人十分困惑,下面以一簡單方 式記住這個功能。當搜索最長匹配時,使用 ##(因為 ## 比 # 長)。當搜索最短匹配時,使用 #。看,不難記吧!等一下,怎樣記住應該使用 '#' 字符來從字符串開始部分除去?很簡單!注意到了嗎:在美國鍵盤上,shift-4 是 "$",它是 bash 變量擴展字符。在鍵盤上,緊靠 "$" 左邊的是 "#"。這樣,可以看到:"#" 位于 "$" 的“開始處”,因此(根據(jù)我們的記憶法),"#" 從字符串的開始處除去字符。您可能要問:如何從字符串末尾除去字符。如果猜到我們使用美國鍵盤上緊靠 "$" 右邊 的字符 ("%),那就猜對了。這里有一些簡單的例子,解釋如何截去字符串的末尾部分:

            $ MYFOO="chickensoup.tar.gz"
            $ echo ${MYFOO%%.*}
            chickensoup
            $ echo ${MYFOO%.*}
            chickensoup.tar

            正如您所見,除了將匹配通配符從字符串末尾除去之外,% 和 %% 變量擴展選項與 # 和 ## 的工作方式相同。請注意:如果要從末尾除去特定子字符串,不必使用 "*" 字符:

            MYFOOD="chickensoup"
            $ echo ${MYFOOD%%soup}
            chicken

            在此例中,使用 "%%" 或 "%" 并不重要,因為只能有一個匹配。還要記住:如果忘記了應該使用 "#" 還是 "%",則看一下鍵盤上的 3、4 和 5 鍵,然后猜出來。

            第二種方法:${varible:n1:n2}:截取變量varible從n1到n2之間的字符串。

            可以根據(jù)特定字符偏移和長度,使用另一種形式的變量擴展,來選擇特定子字符串。試著在 bash 中輸入以下行:

            $ EXCLAIM=cowabunga
            $ echo ${EXCLAIM:0:3}
            cow
            $ echo ${EXCLAIM:3:7}
            abunga

            這種形式的字符串截斷非常簡便,只需用冒號分開來指定起始字符和子字符串長度。

            應用字符串截斷

            現(xiàn)在我們已經(jīng)學習了所有截斷字符串的知識,下面寫一個簡單短小的 shell 腳本。我們的腳本將接受一個文件作為自變量,然后打印:該文件是否是一個 tar 文件。要確定它是否是 tar 文件,將在文件末尾查找模式 ".tar"。如下所示:

            mytar.sh -- 一個簡單的腳本

            #!/bin/bash

            if [ "${1##*.}" = "tar" ]
            then
                echo This appears to be a tarball.
            else
                echo At first glance, this does not appear to be a tarball.
            fi

            要運行此腳本,將它輸入到文件 mytar.sh 中,然后輸入 "chmod 755 mytar.sh",生成可執(zhí)行文件。然后,如下做一下 tar 文件試驗:

            $ ./mytar.sh thisfile.tar
            This appears to be a tarball.
            $ ./mytar.sh thatfile.gz
            At first glance, this does not appear to be a tarball.

            好, 成功運行,但是不太實用。在使它更實用之前,先看一下上面使用的 "if" 語句。語句中使用了一個布爾表達式。在 bash 中,"=" 比較運算符檢查字符串是否相等。在 bash 中,所有布爾表達式都用方括號括起。但是布爾表達式實際上測試什么?讓我們看一下左邊。根據(jù)前面所學的字符串截斷知識,"${1##*.}" 將從環(huán)境變量 "1" 包含的字符串開始部分除去最長的 "*." 匹配,并返回結果。這將返回文件中最后一個 "." 之后的所有部分。顯然,如果文件以 ".tar" 結束,結果將是 "tar",條件也為真。

            您可能會想:開始處的 "1" 環(huán)境變量是什么。很簡單 -- $1 是傳給腳本的第一個命令行自變量,$2 是第二個,以此類推。
            1、
            我用在判斷apache安裝版本的時候用的
            isher@isher-ubuntu:~$ aa=apache_2.0.59
            isher@isher-ubuntu:~$ echo $aa | awk -F_ '{ print $1; }' #F后面的下劃線分割成了apache和2.0.59兩個變量 $1即第一個

            2、寫進度條時候參考過,后來考慮到成本大于使用,就放棄了
            isher@isher-ubuntu:~$ a=12345678
            isher@isher-ubuntu:~$ echo $a|cut -b 2-5
            isher@isher-ubuntu:~$ 2345 #這里是輸出結果

            cut:對標準輸入的字符串進行處理
            cut -bn-m:以byte為單位,從第n個byte開始,取m個
            cut -bn,m:以byte為單位,截取第n,m個byte
            cut -b-n,m:以byte為單位,截取1-n,和第m個
            -c:以charactor為單位
            -d:指定分隔符,默認為tab
            -s:使標準輸入中沒有delimeter
            cut -f1:截取第1個域
            3、字符串截取前后部分內(nèi)容
            echo ${變量#開始字符串*結束字符串} #表示掐頭,因為鍵盤上#在$($就是變量,這樣便于記住)前面,一個表示最小匹配
            echo ${變量%開始字符串r*結束字符串} # %表示去尾,因為鍵盤上%在$后面,一個表示最小匹配

            echo ${變量##開始字符串*結束字符串} 兩個表示最大匹配
            echo ${變量%%開始字符串r*結束字符串} 兩個表示最大匹配
            總結記憶方法
            鍵盤上#$%三個字符連續(xù)的,以$為變量提示符,#即截取變量前的字符,表示截取后面字符

            例子
            isher@isher-ubuntu:~$ aa="No such file or directory" #編寫此文檔時,正好shell開著,提示這行話~ *_^
            isher@isher-ubuntu:~$ echo ${aa#No*dir}
            ectory # 這里就是輸出結果,將No such file or directory 之間的都刪除了,得到就是ectory
            截取后部的意思相同

            isher在簡單說一下##的意思
            isher@isher-ubuntu:~$ aa="No such file or directory" #截取e之后的內(nèi)容,此句話中有兩個e
            如果標記一個#
            isher@isher-ubuntu:~$ echo ${aa#No*e}
            則結果為 or directory
            isher@isher-ubuntu:~$ echo ${aa##No*e}
            ##的結果為 ctory
            截取后部的意思相同

            4、在寫腳本的時候,有一個替換的問題,特提出
            echo ${變量/舊的內(nèi)容/新的內(nèi)容} #替換一個
            echo ${變量//舊的內(nèi)容/新的內(nèi)容} #替換所有

            例子:
            isher@isher-ubuntu:~$ aa="No such file or directory"
            isher@isher-ubuntu:~$ echo ${aa/o/a}
            Na such file or directory #這里僅替換了第一個單詞No的o變?yōu)榱薬

            isher@isher-ubuntu:~$ aa="No such file or directory"
            isher@isher-ubuntu:~$ echo ${aa//o/a}
            Na such file ar directary #這里可以看到,替換這句話(變量)的所有的o為了a了

            1.得到字符串長度
            方法一:
            $echo ${#variable}

            代碼:
            ~$ x="this is a test"
            ~$ echo ${#x}
            14
            方法二:
            $expr length "$variable"

            代碼:
            ~$ x="this is a test"
            ~$ expr length "$x"
            14
            方法三:
            $expr "$variable" : ".*"
            code:
            代碼:
            ~$ x="this is a test"
            ~$ expr "$x" : ".*"
            14
            2.查找字符串子串位置
            方法:
            $expr index "$variable" "substring"
            code:
            代碼:
            ~$ x="this is a test"
            ~$ expr index "$x" "is"
            3
            ~$ expr index "$x" "t"
            1
            (ps:如果出現(xiàn)重復,好象只能查到第一個,第二個,第三個,...,怎么查到呢???)
            3.得到字符串子字符串
            方法一:
            $echo ${variable:position:length}

            代碼:
            ~$ x="this is a test"
            ~$ echo ${x:1:5}
            his i
            方法二:
            $expr substr "$variable" startposition length
            代碼:
            ~$ x="this is a test"
            ~$ expr substr "$x" 1 5
            this
            (ps:注意方法一和方法二中位置的區(qū)別!)
            4.匹配正則表達式之匹配長度
            方法:
            $expr match "$x" "string"

            代碼:
            ~$ x="this is a test"
            ~$ expr match "$x" "his"
            0
            ~$ expr match "$x" "this"
            4
            ~$ expr match "$x" "."
            1
            5.字符串的掐頭去尾
            方法:
            $echo ${variable#startletter*endletter} # #表示掐頭,因為鍵盤上#在$前面,一個表示最小匹配
            $echo ${variable##tartletter*endletter} 兩個表示最大匹配
            $echo ${variable%startletter*endletter} # %表示去尾,因為鍵盤上%在$后面,一個表示最小匹配
            $echo ${variable%%startletter*endletter} 兩個表示最大匹配

            代碼:
            ~$ x="this is a test"
            ~$ echo ${x#t}
            his is a test
            ~$ echo ${x#t*h}
            is is a test
            ~$ echo ${x#t*s}
            is a test

            ~$ echo ${x##t*s}
            t

            ~$ echo ${x%t}
            this is a tes
            ~$ echo ${x%s*t}
            this is a te
            ~$ echo ${x%e*t}
            this is a t

            ~$ echo ${x%%i*t}
            th

            6.字符(串)的替換
            方法:
            $echo ${variable/oldletter/newletter} #替換一個
            $echo ${variable//oldletter/newletter} #替換所有

            代碼:
            ~$ x="this is a test"
            ~$ echo ${x/i/m}
            thms is a test
            ~$ echo ${x//i/m}

            posted on 2010-10-12 19:42 大龍 閱讀(469) 評論(0)  編輯 收藏 引用

            久久er99热精品一区二区| 色播久久人人爽人人爽人人片aV| 国内精品久久久久久久久电影网| 蜜臀av性久久久久蜜臀aⅴ麻豆| 武侠古典久久婷婷狼人伊人| segui久久国产精品| 18岁日韩内射颜射午夜久久成人| 97超级碰碰碰久久久久| 久久亚洲欧美国产精品| 久久中文骚妇内射| 久久精品国产亚洲av高清漫画| 色婷婷综合久久久中文字幕 | 精品水蜜桃久久久久久久| 久久精品国产99国产精品澳门 | 国产精品久久久久久| 国产精品久久影院| 99999久久久久久亚洲| 一级做a爰片久久毛片人呢| 九九热久久免费视频| 亚洲精品乱码久久久久久蜜桃| 久久综合亚洲色HEZYO社区| 男女久久久国产一区二区三区 | 亚洲AV无一区二区三区久久| 99精品久久精品一区二区| 国产麻豆精品久久一二三| 热久久国产精品| 亚洲精品无码久久久久AV麻豆| 日韩精品久久久久久免费| 久久亚洲精品视频| 久久久午夜精品| 蜜桃麻豆www久久| 久久国内免费视频| 97久久精品人妻人人搡人人玩| 精品国产一区二区三区久久蜜臀| 区久久AAA片69亚洲| 国产精品久久亚洲不卡动漫| 亚洲午夜精品久久久久久app| 婷婷久久久亚洲欧洲日产国码AV| 国产成人无码精品久久久久免费 | 99久久精品免费看国产一区二区三区 | 狠狠精品久久久无码中文字幕 |