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