• <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>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            %x=aabbaarealwwvvww
            %echo "${x%w*w}"
            aabbaarealwwvv
            %echo "${x%%w*w}"
            aabbaareal
            %echo "${x##a*a}"
            lwwvvww
            %echo "${x#a*a}"
            bbaarealwwvvww

            其中 , # 表示掐頭, 因為鍵盤上 # 在 $ 的左面。
            其中 , % 表示%,  因為鍵盤上 % 在 $ 的右面。
            單個的表示最小匹配,雙個表示最大匹配。
            也就是說,當匹配的有多種方案的時候,選擇匹配的最大長度還是最小長度。



            象專業(yè)人員那樣截斷字符串


            盡管 basename 和 dirname 是很好的工具,但有時可能需要執(zhí)行更高級的字符串“截斷”,而不只是標準的路徑名操作。當需要更強的說服力時,可以利用 bash 內置的變量擴展功能。已經使用了類似于 ${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" 通配符匹配的子字符串。以下是檢查到的子字符串:


            f   
            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)在我們已經學習了所有截斷字符串的知識,下面寫一個簡單短小的 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 是第二個,以此類推。

            国产精品久久久99| 精品久久久久久国产91| 精品久久久久久国产免费了| 四虎国产精品免费久久5151| 久久国产成人午夜aⅴ影院| 久久伊人色| 亚洲va久久久噜噜噜久久男同| 国产精品视频久久久| 国产精品无码久久久久| 久久精品国产亚洲AV蜜臀色欲 | 亚洲精品高清国产一久久| 久久99热这里只有精品国产| 亚洲精品97久久中文字幕无码| 色偷偷久久一区二区三区| 国产精品美女久久久网AV| 久久久久亚洲精品日久生情 | 97久久精品无码一区二区 | 午夜精品久久久久久99热| 国产一区二区三区久久精品| 天天做夜夜做久久做狠狠| 精品蜜臀久久久久99网站| 亚洲精品午夜国产va久久| 日韩欧美亚洲综合久久影院d3| 国产香蕉久久精品综合网| 国产精品gz久久久| 国产成人久久激情91| 亚洲精品国产字幕久久不卡| 久久天天日天天操综合伊人av| 国产成人久久精品激情| 亚洲色欲久久久综合网东京热| 久久久精品视频免费观看| 91精品国产91久久久久久蜜臀| 久久久女人与动物群交毛片 | 久久人人爽人人爽AV片| 蜜桃麻豆www久久| 久久99精品国产一区二区三区 | 久久国产乱子精品免费女| 久久婷婷五月综合色高清| 囯产精品久久久久久久久蜜桃| 国产精品久久婷婷六月丁香| 亚洲欧美日韩久久精品|