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

            Benjamin

            靜以修身,儉以養(yǎng)德,非澹薄無(wú)以明志,非寧?kù)o無(wú)以致遠(yuǎn)。
            隨筆 - 398, 文章 - 0, 評(píng)論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

            Shell中的數(shù)組

            一、數(shù)組和字符串
            Array[3] = "a b c" echo $Array[1]  輸出b,
            str=“a b c” Array = ($str) echo$Array[1],同樣輸出b,要注意: Array = ($str)中的右值的括號(hào)不能缺
            上面這個(gè)就是我們常說(shuō)的把字符串放到一個(gè)數(shù)組中,也可以理解為動(dòng)態(tài)數(shù)組,比C和C++簡(jiǎn)單多了

            計(jì)算字符串長(zhǎng)度可用的三種方法:
            echo “$str”|awk '{print length($0)}'
            expr length “$str”
            echo “$str”|wc -c
            但是第三種得出的值會(huì)多1,可能是把結(jié)束符也計(jì)算在內(nèi)了

            判斷字符串為空的方法有三種:
            if [ "$str" =  "" ]
            if [ x"$str" = x ]
            if [ -z "$str" ]
            二、其他類(lèi)型的數(shù)組
            arr=(123 34 3 5) echo $arr,輸出123,在這里等同于echo ${arr[0]};
            echo ${arr[1]},輸出34,注意格式,除了首地址,必須要加上{},否則會(huì)出錯(cuò)
            三、數(shù)組的長(zhǎng)度和遍歷
            length=${#array[@]}----數(shù)組的長(zhǎng)度,這里的長(zhǎng)度是最大下標(biāo)
            echo ${array[@]}-------輸出數(shù)組全部元素
            array[1]=5--------------向數(shù)組的某個(gè)元素賦值和標(biāo)c的語(yǔ)法一樣
            echo ${array[@]:1:2}---輸出的是array[0]和array[1]的值
            echo ${array[@]:2}-----輸出數(shù)組第三個(gè)元素以后的值
            echo ${array[@]::2}-----輸出數(shù)組下標(biāo)小于2的值
            $ echo ${#array[3]} ----取得元素3的長(zhǎng)度
            unset array--------------清除array
            array=------------------清空array,賦給array空值

            遍歷字符串方法一
            for ((i=0;i<${#array[@]};i++))
            do
               echo ${array[$i]}
            done

            遍歷字符串方法二
            str="a --m"
            for i in $str
            do
            echo $i
            done

            用while遍歷
            len=${#arr[@]}
            i=0
            while [ $i -lt $len ]
            do
            echo ${arr[$i]}
            let i++
            done

            四、其他:
            Array[3] = "a b c"和Array[3] = a b c這兩個(gè)是等價(jià)的;如果Array[3] = "a "bc"",想要查找",用awk是找不到的,單引號(hào)
            是可以找到的,就是雙引號(hào)找不到;我們可以用截取字符串的方法來(lái)判斷是否雙引號(hào),截取的字符串的方法如下:
            ${varible##*string} 從左向右截取最后一個(gè)string后的字符串
            ${varible#*string}從左向右截取第一個(gè)string后的字符串
            ${varible%%string*}從右向左截取最后一個(gè)string后的字符串
            ${varible%string*}從右向左截取第一個(gè)string后的字符串
            將上面的string換成“即可,然后在判斷字符串的長(zhǎng)度,如果相等就是沒(méi)有,如果不相等就是有雙引號(hào),不可以
            用更改數(shù)組分隔符的方法,那樣做無(wú)效,這個(gè)雙引號(hào)是shell內(nèi)建的符號(hào)。

            通用的awk查找方法,例如:
            find=`echo {${arr[$i]}|awk 'BEGIN{FS=""}{for(i=1;i<=NF;i++) if($i==";") print $i}'`;
            也可以用math和index方法,例如:flag=`echo {$line}|awk '{print match($0,"channel")}'` 
            數(shù)組默認(rèn)的分隔符是空格,如果想改變默認(rèn)的分隔符,用下面的方法
            str="abd#ddd#ff";str2=($(echo $str|tr ''#''|tr -s ''));





            posted on 2010-10-08 22:21 Benjamin 閱讀(26005) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): linux

            99精品国产在热久久无毒不卡 | 亚洲国产天堂久久综合网站| 国产综合久久久久| 99久久精品费精品国产| 久久这里都是精品| 国产一区二区三区久久| 免费久久人人爽人人爽av| 国产一区二区三区久久| 狠狠色丁香久久婷婷综合_中| 久久精品国产乱子伦| 久久青草国产精品一区| 国内精品伊人久久久久777| 91精品国产色综久久| 色偷偷久久一区二区三区| 国产激情久久久久影院老熟女免费| 久久久久久国产a免费观看不卡| 久久精品亚洲男人的天堂| 久久国产精品-国产精品| 国产A三级久久精品| 国产精品久久久久久久app| 国产精品女同一区二区久久| 国产成人久久AV免费| 亚洲精品乱码久久久久66| 久久笫一福利免费导航 | 久久这里的只有是精品23| 色综合久久中文综合网| 精品久久久久久中文字幕人妻最新| 久久中文字幕视频、最近更新 | 精品久久久久久无码国产| 日韩一区二区久久久久久| 狠狠色丁香婷婷久久综合不卡| 久久久精品人妻一区二区三区蜜桃| 国产成人99久久亚洲综合精品 | 国产精品美女久久久久久2018| 久久夜色精品国产亚洲| 狠狠色婷婷久久一区二区| 久久综合偷偷噜噜噜色| 日韩精品无码久久久久久| 久久人人爽爽爽人久久久| 国产成人无码久久久精品一| 日本精品久久久久中文字幕8 |