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

            色婷婷噜噜久久国产精品12p| 国産精品久久久久久久| 国产情侣久久久久aⅴ免费| 国产香蕉97碰碰久久人人| 久久精品18| 亚洲国产成人久久笫一页| 久久这里有精品| AV无码久久久久不卡网站下载| 久久综合九色综合97_久久久| 精品久久久久久无码人妻热| 亚洲欧美日韩久久精品| 欧美精品久久久久久久自慰| 99久久精品费精品国产一区二区 | 97视频久久久| 久久久久亚洲Av无码专| 久久婷婷人人澡人人爽人人爱| 久久精品国产99久久丝袜| 久久免费小视频| 伊人久久精品线影院| 精品综合久久久久久97超人| 色综合久久天天综合| 久久久久亚洲av毛片大| 精品国产日韩久久亚洲| 久久AV高清无码| 精品久久久无码中文字幕| 国产精品99久久久久久猫咪 | 久久人人爽人人人人爽AV| 亚洲国产精品狼友中文久久久| 久久亚洲精品无码观看不卡| 模特私拍国产精品久久| 老色鬼久久亚洲AV综合| 国产高清国内精品福利99久久| 久久午夜夜伦鲁鲁片免费无码影视| 久久成人18免费网站| 久久久久国产精品熟女影院 | 精品伊人久久久| 国产产无码乱码精品久久鸭| 久久久久国产一区二区三区| 无码人妻精品一区二区三区久久久| 久久亚洲精品视频| 69久久精品无码一区二区|