數組及變量的多功能用法
一、數組:
1、數組:存儲多個元素的連續的內存空間,相當于多個變量的集合(變量:存儲單個元素的內存空間)。
2、數組名和索引
索引:編號從0開始,屬于數值索引
bash的數組支持稀疏格式(索引不連續)
注意:索引可支持使用自定義的格式,而不僅是數值格式,即為關聯索引,bash4.0版本之后開始支持。
聲明數組:
declare -a ARRAY_NAME
declare -A ARRAY_NAME: 關聯數組
3、數組元素的賦值:
(1) 一次只賦值一個元素:arr[index]=value
(2) 一次賦值全部元素:arr=(value) ;括號里面的元素值要使用空格分開
(3) 只賦值特定元素:
(4) 交互式數組值對賦值
read -a ARRAY
注:數組的賦值取消,命令:unset 數組名
4、數組的引用:
引用數組元素:${arr[INDEX]}
注意:arr[INDEX]表示引用下標為0的元素
數組的長度(數組中元素的個數):
${#arr[*]}
${#arr[@]}
5、數組數據處理:
(1)引用數組中的元素:
所有元素:${arr[@]}, ${arr[*]}
(2)數組切片:
${arr[@]:offset:number} (offset: 要跳過的元素個數;number: 要取出的元素個數)
如下圖,${arr[@]:2}:從左往右切掉兩個元素值
${arr[@]:2:3}:從左往右先切掉兩個元素值,再緊接著切所需要的三個元素值。
${arr[@]:offset } (offset為負數,前面注意要有空格)從右往左取出所需的元素個數
${arr[@]:offset:number}
取偏移量之后的所有元素${arr[@]:offset}
(3)向數組中追加元素:
arr[${#arr[*]}]
(4)刪除數組中的某元素:導致稀疏格式
unset arr[INDEX]
(5)關聯數組:
declare -A arr 注意:必須先聲明,再調用
arr=([idx_name1]='val1' [idx_name2]='val2‘…)
事例:輸入若干個數值存入數組中,采用冒泡算法進行升序或降序排序
腳本代碼:
腳本執行效果:
二、字符串處理:
1、bash的字符串處理工具--——字符串切片:
${#var}:返回字符串變量var的長度
${var:offset}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字符開始,到最后的部分,offset的取值在0 到${#var}-1 之間(bash4.2后,允許為負值)
(如下圖,去掉左邊起的五個字符,取剩下的字符)
${var:offset:number}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字符開始,長度為number的部分
(如下圖,去掉左邊的五個字符,再取從左邊起的三個字符)
${var: -lengh}:取字符串的最右側幾個字符(注意:冒號后必須有一空白字符)
(如下圖,只取從右邊起的四個字符)
${var:offset:-lengh}:從最左側跳過offset字符,一直取到字符串的最右側lengh個字符之前
(如下圖,步驟是去掉左邊的三個字符,再去掉右邊三個字符,取剩下的字符)
2、基于模式取子串:
${var#*string}:其中string可以是指定的任意字符;功能:自左而右,查找var變量所存儲的字符串中,第一次出現的string, 刪除字符串開頭至第一次出現string字符之間的所有字符
${var##* string }:同上,不同的是,刪除的是字符串開頭至最后一次由string指定的字符之間的所有內容
${var%string*}:其中word可以是指定的任意字符;功能:自右而左,查找var變量所存儲的字符串中,第一次出現的string, 刪除字符串最后一個字符向左至第一次出現string字符之間的所有字符;
${var%% string*}:同上,只不過刪除字符串最右側的字符向左至最后一次出現string字符之間的所有字符;
3、查找替換:
${var/pattern/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替換之
${var//pattern/substi}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi替換之
${var/#pattern/substi}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替換之
${var/%pattern/substi}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替換之
4、查找并刪除:
${var/pattern}:查找var所表示的字符串中,刪除第一次被pattern所匹配到的字符串
${var//pattern}:所有
${var/#pattern}:行首
${var/%pattern}:行尾
4、字符大小寫轉換:
${var^^}:把var中的所有小寫字母轉換為大寫
${var,,}:把var中的所有大寫字母轉換為小寫
三、變量:
1、變量賦值:
${var:-value}:如果var為空或未設置,那么返回value;否則,則返回var的值
${var:+value}:如果var不空,則返回value,否則返回空值
${var:=value}:如果var為空或未設置,那么返回value,并將value賦值給var;否則,則返回var的值
${var:?error_info}:如果var為空或未設置,那么在當前終端打印error;否則,則返回var的值
為腳本程序使用配置文件,實現變量賦值:
(1) 定義文本文件,每行定義“name=value”
(2) 在腳本中source此文件即可
2、高級變量用法–有類型變量:
(1)Shell變量一般是無類型的,但是bash Shell提供了declare和typeset兩個命令用于指定變量的類型,兩個命令是等價的
(2)declare [選項] 變量名
-r 將變量設置為只讀屬性
-i 將變量定義為整型數
-a 將變量定義為數組
-A 將變量定義為關聯數組
-f 顯示此腳本前定義過的所有函數名及其內容
-F 僅顯示此腳本前定義過的所有函數名
-x 將變量聲明為環境變量
-l 將變量值轉為小寫字母declare –l var=UPPER
-u 將變量值轉為大寫字母declare –u var=lower
3、間接變量引用:
如果第一個變量的值是第二個變量的名字,從第一個變量引用第二個變量的值就稱為間接變量引用。
例:var1=var2;而var2=`hostname`
通過var1來顯示var2的值。
bash Shell提供了兩種格式實現間接變量引用:
eval tempvar=\$$variable1
tempvar=${!variable1}
eval命令將會首先掃描命令行進行所有的置換,然后再執行該命令。該命令適用于那些一次掃描無法實現其功能的變量。該命令對變量進行兩次掃描
四、創建臨時文件:
mktemp命令:創建的臨時文件可避免沖突
使用格式:mktemp[OPTION]… [TEMPLATE] (TEMPLATE: filename.XXX)
X至少要出現三個
使用選項:
-d: 創建臨時目錄
-p DIR或–tmpdir=DIR:指明臨時文件所存放目錄位置
五、安裝復制文件:
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
六、bash是如何展開命令行:
a、把命令行分成單個命令詞
b、展開別名
c、展開大括號種的聲明({})
d、展開波浪符聲明(~)
e、命令替換$()和“)
f、再次把命令行分成命令詞
g、展開文件通配(*、?、[abc]等等)
h、準備I/0重導向(<、>)
i、運行命令
七、防止擴展:
反斜線(\)會使隨后的字符按原意解釋
$echoYourcost:\$5.00
Yourcost:$5.00
加引號來防止擴展
單引號(’)防止所有擴展
雙引號(”)也防止所有擴展,但是以下情況例外:
$(美元符號)-變量擴展
`(反引號)-命令替換
\(反斜線)-禁止單個字符擴展
!(嘆號)-歷史命令替換
函數例題
1、編寫服務腳本/root/bin/testsrv.sh,完成如下要求
(1) 腳本可接受參數:start, stop, restart, status
(2) 如果參數非此四者之一,提示使用格式后報錯退出
(3) 如是start:則創建/var/lock/subsys/SCRIPT_NAME, 并顯示“啟動成功”
考慮:如果事先已經啟動過一次,該如何處理?
(4) 如是stop:則刪除/var/lock/subsys/SCRIPT_NAME, 并顯示“停止完成”
考慮:如果事先已然停止過了,該如何處理?
(5) 如是restart,則先stop, 再start
考慮:如果本來沒有start,如何處理?
(6) 如是status, 則如果/var/lock/subsys/SCRIPT_NAME文件存在,則顯示“SCRIPT_NAME is running…”
如果/var/lock/subsys/SCRIPT_NAME文件不存在,則顯示“SCRIPT_NAME is stopped…”
其中:SCRIPT_NAME為當前腳本名
腳本代碼:
腳本執行效果:
2、編寫腳本/root/bin/copycmd.sh
(1) 提示用戶輸入一個可執行命令名稱
(2) 獲取此命令所依賴到的所有庫文件列表
(3) 復制命令至某目標目錄(例如/mnt/sysroot)下的對應路徑下;
如:/bin/bash ==> /mnt/sysroot/bin/bash
/usr/bin/passwd==> /mnt/sysroot/usr/bin/passwd
(4) 復制此命令依賴到的所有庫文件至目標目錄下的對應路徑下:
如:/lib64/ld-linux-x86-64.so.2 ==> /mnt/sysroot/lib64/ld-linux-x86-64.so.2
(5)每次復制完成一個命令后,不要退出,而是提示用戶鍵入新的要復制的命令,并重復完成上述功能;直到用戶輸入quit退出
腳本代碼:
腳本執行效果:
原創文章,作者:Aaron_wang,如若轉載,請注明出處:http://www.www58058.com/40169
文章對bash數組的用法有了完整性的總結,也通過示例展示了如何使用數組,突顯作者的用心程度。