您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關Shell中數(shù)組的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
Shell中數(shù)據(jù)類型不多,比如說字符串,數(shù)字類型,數(shù)組。數(shù)組是其中比較重要的一種,其重要應用場景,可以求數(shù)組長度,元素長度,遍歷其元素,元素切片,替換,刪除等操作,使用非常方便。
Shell中的數(shù)組不像JAVA/C,只能是一維數(shù)組,沒有二維數(shù)組;數(shù)組元素大小無約束,也無需先定義數(shù)組的元素個數(shù);但其索引則像JAVA/C/Python,從0開始,下面其常用的方式進行總結.
備注:
1) 不像JAVA/C等強編程語言,在賦值前必須聲明;SHELL只是弱編程語言,可事先聲明也可不聲明;
2) 用unset來撤銷數(shù)組,可用unset array_name[i]來刪除里面的元素
備注:
1) 數(shù)組中的元素,必須以"空格"來隔開,這是其基本要求;
2) 定義數(shù)組其索引,可以不按順序來定義,比如說:names=([0]=Jerry [1]=Alice [2]=David [8]=Wendy);
3)字符串是SHELL中最重要的數(shù)據(jù)類型,其也可通過($str)來轉成數(shù)組,操作起來非常方便;
備注:
1) 使用${array_name[@]} 或者 ${array_name[*]} 都可以全部顯示數(shù)組中的元素
2) 同樣道理${#array_name[@]} 或者 ${#array_name[*]}都可以用來求數(shù)組的長度
3)求數(shù)組中元素的長度方法有很多,相當于求字符串的長度
[root@locathost ~]# s="A,B,C,D" [root@locathost ~]# a=(`echo $s | tr ',' ' '`) # 將字符串轉變成數(shù)組 [root@locathost ~]# echo ${!a[@]} # 求數(shù)組中的索引 0 1 2 3
【元素刪除】
[root@localhost ~]# a=(A B C D) [root@localhost ~]# unset a[2] # 刪除索引為2的元素 [root@localhost ~]# echo ${a[@]} # 顯示刪除后的元素 A B D
腳本輸出:
備注:
1) 可以使用標準的for循環(huán),這種類C語言的方式來遍歷數(shù)組中的元素
2) for 元素 in 元素集(數(shù)組) 這種類Python的方式來遍歷數(shù)組
3)從代碼可讀性與執(zhí)行速度來看,推薦使用第二種方式
備注:
1) 第一種是給已經(jīng)存在的元素項重新賦值
2) 當然也可以給不存在的索引添加賦值,可以看下面的示例
數(shù)組切片
元素切片
備注:
1) 通用的格式${array[@]:起始位置:長度},中間以":"隔開,如果第二項省略的話,就取后面所有的項
2) 切片后返回的是字符串,可以通過 新數(shù)組=(${舊數(shù)組[@]:索引:長度})來索引,參見上面最后一個例子
3) 區(qū)別于Python之一:起始位置可以為負數(shù),但必須以放在()中,長度不能為負數(shù)
4)區(qū)別于Python之二:第二項在Python里面是結束索引,在Shell則代表所取元素的長度
5) 區(qū)別于Python之三:Python可以通過 list[-1:-4:-2]來反向取數(shù),在Shell則實現(xiàn)不了
${array[@]/x/y} 最小匹配替換,每個元素只替換一次
${array[@]//x/y} 最大匹配替換,每個元素可替換多次
${array[@]/x/} 最小匹配刪除,只刪除一個符合規(guī)定的元素
${array[@]//x/} 最大匹配刪除,可刪除多個符合規(guī)定的元素
${array[@]/#x/y} 從左往右匹配替換,只替換每個元素最左邊的字符
${array[@]/%x/y} 從右往左匹配替換,只替換每個元素最右邊的字符
# 每個元素,從左向右進行最短匹配
## 每個元素,從左向右進行最長匹配
% 每個元素,從右向左進行最短匹配
%% 每個元素,從右向左進行最長匹配
示例一: 將ifconfig命令取到的本地IP: 127.0.0.1逐行顯示出來
腳本輸出:
示例二: 模擬堆棧的push,pop,shift,unshift操作
腳本輸出:
示例三: 在1-10間,隨機生成10個不重復的數(shù),將其放置于數(shù)組中
腳本輸出:
備注:
1) 生成[1,10]范圍內(nèi)不重復的隨機整數(shù),并保存到數(shù)組array中
2) seq 1 10 用于生成1~10的整數(shù)序列(包含邊界值1和10)
3) awk中的rand()函數(shù)用于隨機產(chǎn)生一個0到1之間的小數(shù)值(保留小數(shù)點后6位)
4)rand()只生成一次隨機數(shù),要使用srand()函數(shù)使隨機數(shù)滾動生成
5) 括號里留空即默認采用當前時間作為隨機計數(shù)器的種子,這樣以秒為間隔,隨機數(shù)就能滾動隨機生成了
6) 由于以秒為間隔,所以如果快速連續(xù)運行兩次腳本(1s內(nèi)),你會發(fā)現(xiàn)生成的隨機數(shù)還是一樣的
示例四: 將字符串處理后轉為為數(shù)組,再對其打印輸出
腳本輸出:
示例五: 用read -a參數(shù),從標準輸入中讀取數(shù)組,再做操作
腳本輸出:
示例六: 判斷某個變量,是否在數(shù)組中,在輸出YES,否輸出NO
腳本輸出:
示例七: 對數(shù)組中的元素進行排序
示例八: 將/etc/passwd文件中以:分隔的第一列,即用戶名放置于一個數(shù)組中
示例九: 將1-8,每個數(shù)自乘后輸出
腳本輸出:
示例十: 借助數(shù)組來設置SHELLS的環(huán)境變量
示例十一: 設置IFS,讀取文件內(nèi)容示例
示例十二: 利用eval,模擬實現(xiàn)數(shù)組的功能
腳本輸出:
示例十三: 利用數(shù)組來實現(xiàn)冒泡排序
思路:會重復地走訪過要排序的數(shù)組,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數(shù)列的工作是重復地進行直到?jīng)]有再需要交換,也就是說該數(shù)列已經(jīng)排序完成。越大的元素會經(jīng)由交換慢慢“浮”到數(shù)列的頂端
腳本輸出:
示例十四: 利用數(shù)組來求最大值
腳本輸出
感謝各位的閱讀!關于“Shell中數(shù)組的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。