數組:存放多個元素的連續內存空間。
聲明數組:bash-4以后支持除默認的0,1,2……還可以自定義索引格式,此類數組稱之為“關聯數組”
聲明索引數組:declare -a NAME
聲明關聯數組:declare -A NAME
索引數組賦值:
索引方式賦值:ARRAY_NAME[INDEX]=value
ARRAY_NAME=("value1" "value2" ……)
ARRAY_NAME=value([0]="value1" [3]="value2")
交互式賦值:read -a ARRAY_NAME
關聯數組賦值
ARRAY_NAME=([INDEX_NAME1]="VALUE1") [INDEX_NAME2]="VALUE2").....)
數組索引:代表元素所在數組的位置屬性,從0開始。
格式:數組名[索引]
引用數組中某個元素:${ARRAY_NAME[INDEX]}
當不給出INDEX時默認值為0,引用數組中個某一元素值時一定要使用${}。
數組切片:
${ARRAY_NAME[@]:offset:number}
offset:偏移量,要跳過的元素個數
number:要取出的元素個數;省略number,表示取偏移量之后的所有元素
增加元素:
ARRAY_NAME[${#ARRAY_NAME[*]}]=
${ARRAY_NAME[*]}:數組中元素個數
刪除元素:
unset ARRAY[INDEX]
字符串處理:
字符串切片:
${var:offset:number},取字符串的子串。
${var: -length}:從右側取length個字符。
注意:冒8號后一定要有一個空格。
基於分隔符取子串
${var#*word}:
word:指定的分隔符。
功能:自左而右,查找var變量中所存儲的字符串中,第一次出現的word分隔符,刪除字符串開頭至此分隔符之間的所有字符。
${var##*word}:
word:指定的分隔符。
功能:自左而右,查找var變量中所存儲的字符串中,最后一次出現的word分隔符,刪除字符串開頭至此分隔符之間的所有字符。
${var%word*}:
word:指定的分隔符。
功能:自右而左,查找var變量中所存儲的字符串中,第一次出現的word分隔符,刪除字符串尾部至此分隔符之間的所有字符。
${var%%word*}:
word:指定的分隔符。
功能:自右而左,查找var變量中所存儲的字符串中,最后一次出現的word分隔符,刪除字符串尾部至此分隔符之間的所有字符。
查找替換:
${var/PATTERN/SUBSTITUTE}:查找var所表示的字符串中,將第一次被PATTERN所匹配的字符串,替換為SUBSTITUTE所表示的字符串。
${var//PATTERN/SUBSTITUTE}:查找var所表示的字符串中,將所有被PATTERN所匹配的字符串,替換為SUBSTITUTE所表示的字符串。
${var/#PATTERN/SUBSTITUTE}:查找var所表示的字符串中,行首被PATTERN所匹配的字符串,將其替換為SUBSTITUTE所表示的字符串。
${var/%PATTERN/SUBSTITUTE}:查找var所表示的字符串中,行尾被PATTERN所匹配的字符串,將其替換為SUBSTITUTE所表示的字符串。
查找刪除:
${var/PATTER}:將var中第一次被PATTERN匹配的字符串刪除。
${var//PATTER}:將var中所有被PATTERN匹配的字符串刪除。
${var/#PATTER}:將var中行首被PATTERN匹配的字符串刪除。
${var/%PATTER}:將var中行尾被PATTERN匹配的字符串刪除。
大小寫轉換:
${var^^}:把var中所有小寫字符轉換成大寫。
${var,,}:把var中所有大寫字符轉換成小寫。
變量賦值:
${var:-VALUE}:如果var變量為空或未設置,那么返回value;否則返回var變量的值
${var:=value}:如果var變量為空或未設置,那么返回value,並將VALUE賦值給變量var;否則返回var變量的值
${var:?ERROR_INFO}:如果var變量為空或未設置,那么返回ERROR_INFO;否則返回var變量的值
${var:+VALUE}:如果var變量不為空,那么返回value;