數組定義:
變量:存儲單個元素的內存空間
數組:存儲多個元素的連續的內存空間,相當于多個變量的集合
數組名和索引:
索引:編號從0開始,屬于數值索引
注意:索引可支持使用自定義的格式,而不僅僅是數值格式,自定義格式的數組即為關聯數組,bash4.0版本之后開始支持
bash的數組支持稀疏格式(索引不連續)
聲明數組:
declare -a ARRAY_NAME
declare -A ARRAY_NAME:關聯數組 //所謂的索引號可以不是數字,而是字母或其他
數組元素的賦值:
(1)一次只賦值一個元素;
ARRAY_NAME[INDEX]=VALUE
weekdays[0]="Sunday"
weekdays[4]="Thursday"
(2)一次賦值全部元素:
ARRAY_NAME=("VAL1" "VAL2" "VAL3" …)
(3)只賦值特定元素:
ARRAY_NAME=([0]="VAL1" [3]="VAL2" …)
(4)交互式數組值對賦值
read -a ARRAY
數組的長度(數組中元素的個數):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
注意:若數組不為稀疏格式,則屬組元素個數等于最后一個數組的索引號+1
注意:若數組為稀疏格式,則屬組元素個數不等于最后一個數組的索引號+1
引用數組中的元素:
${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下標為0的元素
所有元素:
${ARRAY[@]}
${ARRAY[*]}
數組切片:
${ARRAY[@]:offset:number}
offset: 要跳過的元素個數
number: 要取出的元素個數
取偏移量之后的所有元素:
${ARRAY[@]:offset}
向數組中追加元素:
ARRAY[${#ARRAY[*]}]
${#ARRAY[*]}為當前數組的元素個數
刪除數組中的某元素:導致稀疏格式
unset ARRAY[INDEX]
關聯數組:
必須先定義后使用
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)
作業:生成10個隨機數,采用冒泡算法進行升序或降序排序
#!/bin/bash #description Bubble sort #version 0.1 #author gaomeng #date 20160823 # declare -a string for i in {0..9};do string[$i]=$[$RANDOM%100+1] done echo ${string[*]} for i in {0..8};do for (( j=i+1 ; j<=9 ; j++ )) ;do if [ ${string[$i]} -lt ${string[$j]} ];then t=${string[$i]} string[$i]=${string[$j]} string[$j]=$t fi done done echo ${string[*]}
[root@CentOS6 bin]# string1.sh 37 83 64 42 74 59 38 19 83 25 83 83 74 64 59 42 38 37 25 19 [root@CentOS6 bin]# string1.sh 52 6 63 71 67 88 88 12 76 80 88 88 80 76 71 67 63 52 12 6 [root@CentOS6 bin]# string1.sh 92 20 92 94 11 97 46 100 2 44 100 97 94 92 92 46 44 20 11 2 [root@CentOS6 bin]# string1.sh 64 33 19 44 16 83 5 100 13 40 100 83 64 44 40 33 19 16 13 5
練習:斐波那契數列又稱黃金分割數列,因數學家列昂納多?斐波那契以兔子繁殖為例子而引入,故又稱為“兔子數列”,指的是這樣一個數列:0、1、1、2、3、5、8、13、21、34、……,斐波納契數列以如下被以遞歸的方法定義:F(0)=0,F(1)=1,F(n)=F(n-1)+F(n-2)(n≥2),用數組方式實現
0 1 2 3 4 5 6 7 8 9
0、1、1、2、3、5、8、13、21、34
#!/bin/bash #description #version 0.1 #author gaomeng #date 20160820 # declare -a string string[0]=0 string[1]=1 read -p "Please input month number: " num until echo $num | grep -qE "^[0-9]+$";do read -p "your number error, Input month number: " num done if [ $num -eq 0 ];then echo "sum is ${sting[0]}" elif [ $num -eq 1 ];then echo "sum is ${sting[1]}" else i=2 while [ $i -le $num ];do let string[$i]=${string[$i-1]}+${string[$i-2]} let i++ done echo "sum is ${string[$num]}" fi
[root@CentOS6 bin]# string5.sh Please input month number: 8 sum is 21 [root@CentOS6 bin]# string5.sh Please input month number: 9 sum is 34 [root@CentOS6 bin]# string5.sh Please input month number: 24 sum is 46368
bash的字符串處理工具:
字符串切片:
${#var}:返回字符串變量var的長度
${var:offset}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字符開始,到最后的部分,offset 的取值在0到${#var}-1之間(bash4.2后,充許為負值)
${var:offset:number}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字符開始 ,長度為number的部分
${var: -lengh}:取字符串的最右側幾個字符:
注意:冒號后必須有一空白字符
基于模式取子串:
${var#*word} :其中word可以是指定的任意字符功能:自左而右,查找var變量所存儲的字符串中,第一次出現的word,刪除字符串開頭至第一次出現word字符之間的所有字符
${var##*word} :同上,不同的是,刪除的是字符串開頭至最后一次由word指定的字符之間的所有內容
file="/var/log/messages"
${file##*/} ==> messages //取基名
${var%word*}:其中word可以是指定的任意字符;功能:自右而左,查找var變量所存儲的字符串中,第一次出現的word,刪除字符串最后一個字符向左至第一次出現word字符之間的所有字符;
file="/var/log/messages"
${file%/*} ==> /var/log //取路徑名
${var%%word*} :同上,只不過刪除字符串最右側的字符向左至最后一次出現word字符之間的所有字符;
示例:url=http://www.magedu.com:80
${url##*:} ==> 80
${url%%:*} ==> http
查找替換:
${var/pattern/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替換之
${var//pattern/substi}:查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi替換之
${var/#pattern/substi}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替換之
${var/%pattern/substi}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替換之
查找并刪除:
${var/pattern}:查找var所表示的字符串中,刪除第一次被pattern所匹配到的字符串
${var//pattern}:刪除所有pattern所匹配到的字符串,其余字符串相對位置不變
${var/#pattern}:刪除行首pattern所匹配到的字符串,其余字符串相對位置不變
${var/%pattern}:刪除行尾pattern所匹配到的字符串,其余字符串相對位置不變
字符大小寫轉換:
${var^^}:把var中的所有小寫字母轉換為大寫
${var,,}:把var中的所有大寫字母轉換為小寫
變量賦值:
${var:-value} :如果var為空或未設置,那么返回value;否則,則返回var的值
${var:+value} :如果var不空,則返回value
${var:=value} :如果var為空或未設置,那么返回value,并將value賦值給var;否則,則返回var的值
${var:?error_info} :如果var為空或未設置,那么返回error_info;否則,則返回var的值
為腳本程序使用變量配置文件, 實現變量引用和賦值:
(1)定義name文本文件,每行定義“name=value”
(2)若要引用name文件中定義的變量名及其值,則在腳本中source name
Shell變量一般是無類型的,但是bash Shell提供了declare和typeset兩個命令用于指定變量的類型,兩個命令是完全等價的
declare [ 選項] 變量名
-r:將變量設置為只讀屬性
-i:將變量定義為整型數
-a:將變量定義為數組
-f:顯示此腳本前定義過的所有函數名及其內容
-F:僅顯示此腳本前定義過的所有函數名
-x:將變量聲明為環境變量
-l:將變量值轉為小寫字母
-u:將變量值轉為大寫字母
變量引用:
如果第一個變量的值是第二個變量的名字,從第一個變量引用第二個變量的值就稱為間接變量引用
gm=gaomeng
gaomeng=haha
gm的值是gaomeng,而gaomeng又是變量名,
gaomeng的值為haha,間接變量引用是指通過gm獲得變量值haha
bash Shell提供了兩種格式實現間接變量引用
eval string=\$$gm
string=${!gm}
示例:
[root@CentOS6 ~]# gm=gaomeng [root@CentOS6 ~]# gaomeng=hehe [root@CentOS6 ~]# string1=${!gm} [root@CentOS6 ~]# echo $string1 hehe [root@CentOS6 ~]# eval string2=\$$gm [root@CentOS6 ~]# echo $string2 heheeval命令將會首先掃描命令行進行所有的置換,然后再執行該命令。該命令適用于那些一次掃描無法實現其功能的變量。該命令對變量進行兩次掃描
mktemp命令:
創建臨時文件
可以避免文件名沖突
mktemp [OPTION]… [TEMPLATE]
TEMPLATE: filename.XXX
X至少要出現三個
OPTION:
-d:創建臨時目錄
–tmpdir=/DIR:指明臨時文件所存放的目錄位置
[root@CentOS6 testdir]# ls [root@CentOS6 testdir]# mktemp file.XXX file.I3A [root@CentOS6 testdir]# mktemp file.XXX file.AKG [root@CentOS6 testdir]# mktemp file.XXX file.XuG [root@CentOS6 testdir]# ll total 0 -rw-------. 1 root root 0 Aug 21 09:30 file.AKG -rw-------. 1 root root 0 Aug 21 09:29 file.I3A -rw-------. 1 root root 0 Aug 21 09:30 file.XuG
install命令:
install [OPTION]… [-T] SOURCE DEST 單文件
install [OPTION]… SOURCE… DIRECTORY
install [OPTION]… -t DIRECTORY SOURCE…
install [OPTION]… -d DIRECTORY… 創建空目錄
選項:
-m MODE ,默認755
-o OWNER
-g GROUP
install命令的特殊用法:
假設有這樣一個實驗環境,你使用了chmod命令,修改了chmod配置文件的權限為000,則chmod命令無法使用,即使重啟系統依舊無法使用,怎么辦?
[root@CentOS6 ~]# which chmod /bin/chmod [root@CentOS6 ~]# ll /bin/chmod -rwxr-xr-x. 1 root root 52472 May 11 16:59 /bin/chmod [root@CentOS6 ~]# chmod 000 /bin/chmod [root@CentOS6 ~]# ll /bin/chmod ----------. 1 root root 52472 May 11 16:59 /bin/chmod [root@CentOS6 ~]# chmod 777 /bin/chmod //chmod命令已經無法使用 -bash: /bin/chmod: Permission denied [root@CentOS6 ~]# touch a [root@CentOS6 ~]# ll a -rw-r--r--. 1 root root 0 Aug 21 09:25 a [root@CentOS6 ~]# chmod 755 a //chmod命令已經無法使用 -bash: /bin/chmod: Permission denied [root@CentOS6 ~]# install /bin/chmod ./ //復制二進制文件到當前目錄 [root@CentOS6 ~]# ll chmod //當前目錄下的chmod命令成了755的權限 -rwxr-xr-x. 1 root root 52472 Aug 21 09:25 chmod [root@CentOS6 ~]# /root/chmod 755 /bin/chmod //用當前目錄下的chmod命令修改原命令二進制文件的權限 [root@CentOS6 ~]# ll /bin/chmod -rwxr-xr-x. 1 root root 52472 May 11 16:59 /bin/chmod
原創文章,作者:megedugao,如若轉載,請注明出處:http://www.www58058.com/39275
文章層次結構清晰,內容整體很完整,實驗性驗證和歷史背景介紹讓文章整體更有說服力,突顯用心。