bash基礎特性:
命令行展開:~,{}
命令別名:alias,unalias
命令歷史:history
命令和路徑補全:$PATH
glob通配符:*,?,[],[^],
快捷鍵:Ctrl+{a,e,l,c,u,k}
命令hash:
bash通配符及特殊符號:
通配符:
?:任意一個字符;
*:匹配任意個任意字符;
[]:匹配括號內的任意一個字符;
[^]:匹配非括號內的任意一個字符
特殊字符:
‘ ‘:單引號中,所有特殊字符都沒有特殊含義;
” “:雙引號中,除$(調用變量的值)、`(命令引用)、\(轉義符)外,其他特殊字符沒有特殊含義;
` `:等同于$();達到命令引用,即先執行本處命令;
\:轉義符,使跟\之后的特殊字符失去特殊含義;
$:調用變量的值;
#:在shell腳本中,#開頭的行代表注釋
bash腳本:
運行腳本:1、給予執行權限,通過具體的文件路徑指定文件執行;
2、直接運行解釋器,將腳本作為解釋器程序的參數運行;
數據類型:
一、字符
二、數值
1、整型
2、浮點型
(1)、單精度浮點型
(2)、雙精度浮點型
3、布爾型
bash中的算術運算:man let
+,-,*,/,%
實現算術運算:(乘法符號有些場景中需轉義\)
1、let var=算術表達式;例如 let sum=$num1+$num2
2、var=$[算術表達式];例如 echo $[$num1+$num2]
3、var=$((算術表達式));例如echo $(($num1+$num2))
4、var=$(expr arg1 arg2 arg3 …);例如sum=$(expr $num1 + $num2)
bash內建的隨機數生成器:$RANDOM;
例如取出0-60之間# echo $[$RANDOM%60+1]
增強型賦值:man let;自增、自減:
+=,-=,*=,/=,%=
例如let count+=1、let count++
條件測試:判斷某需求是否滿足,需要有測試機制來實現;
測試命令:
test EXPRESSION
[ EXPRESSION ]
[[ EXPRESSION ]]
bash的測試類型:
一、數值測試:
-gt:大于;
-lt:小于;
-ge:大于等于;
-le:小于等于;
-eq:等于;
二、字符串測試:(注意:用于字符串比較的操作數要使用引號)
==:等于;
>:大于;
<:小于;
!=:不等于;
=~:左側字符串是否被右側pattern所匹配;此表達式一般用于[[ ]]中;
-z “string”:字符串是否為空,空則為真,不空則為假;
-n “string”:字符串是否非空,非空為真,空則為假;
三、文件測試:(man bash)
-e file:存在測試;
-b file:存在且為塊設備文件;
-c file:存在且為字符設備文件;
-d file:存在且為目錄文件;
-f ?file:存在且為普通文件;
-g file:存在且擁有sgid權限;
-u file:存在且擁有suid權限;
-k file:存在且擁有sticky權限;
-r file:存在且可讀;
-w file:存在且可寫;
-x file:存在且可執行;
-s file:存在且非空;
-t fd:fd表示文件描述符是否已經打開且與某終端相關;
file1 -ef file2:是否為同一個設備上的相同inode;
file1 -nt file2:file1是否新于file2;
file1 -ot file2:file1是否舊于file2;
組合測試條件:
第一種方式:
command1 && command2
command1 || command2
! command
例如:[ -z “$(hostname)” ] || [ “$(hostname)” == “localhost.localdomain” ]
第二種方式:
expression1 -a expression2
expression1 -o expression2
! expression
例如:[ -z “$(hostname)” -o “$(hostname)” == “localhost.localdomain” ]
bash自定義退出狀態碼:
exit [n]:自定義退出狀態碼;
注意:腳本中一旦遇到exit命令,腳本會立即終止;終止狀態碼取決于exit命令后的數字;
注意:如果未給腳本指定狀態退出碼,整個腳本的退出狀態碼取決于腳本中執行的最后一條命令的狀態碼;
bash編程之用戶交互:
read -p “提示語” 變量名
bash腳本編程:
整數值比較:-ge 大于等于; -gt 大于; -eq 相等; -lt 小于; -ne 不相等;-le小于等于
順序執行
選擇執行:if、case
循環執行:for、while、until
函數:結構化編程及代碼重用;function
選擇執行:if語句(逐條件進行判斷;第一次遇到為“真”條件時,執行其分支,而后結束)
單分支:
if 判斷條件;then
條件為真的分支代碼
fi
雙分支:
if 判斷條件;then
條件為真的分支代碼
else
條件為假的分支代碼
fi
多分支:
if 判斷條件1;then
條件為真的分支代碼
elif 判斷條件2;then
條件為真的分支代碼
elif 判斷條件3;then
條件為真的分支代碼
…
else
條件為假的分支代碼
fi
case語句
case $變量名 in
模式1)
命令序列1
;;
模式2)
命令序列2
;;
*)
默認執行的命令序列
;;
esac
bash編程之for語句
循環執行:for語句
for 變量 in 列表;do
循環體
done
for循環的特殊格式:
for ((控制變量初始化;條件判斷表達式;控制變量的修正表達式));do
循環體
done
控制變量初始化:僅在運行到循環代碼段時執行一次;
控制變量的修正表達式:每輪循環結束會先進行控制變量修正運算,而后再做條件判斷;
列表生成方式:
(1)直接給出列表;例如 for i in 1 2 3 4;then…
(2)整數列表:
(a){start..end};例如{1..10}代表1-10;
(b)$(seq [start [step]] end);例如:$(seq 1 2 10),代表10以內的奇數;
(3)返回列表的命令:$(COMMAND);例如$(ls /var)代表對列出/var目錄下的文件列表;
(4)glob通配符
while語句:當條件為true時進入循環,條件為false時退出循環;
while 條件;do
循環體
done
while循環的特殊用法(遍歷文件的每一行):依次讀取/path/to/somefile文件中的每一行,且將行賦值給變量line;
while read line;do
循環體
done < /path/to/somefile
until語句:當條件為false時進入循環,條件為true時退出循環;
until 條件;do
循環體
done
創建死循環:
while true;do
循環體
done
until false;do
循環體
done
循環控制語句(用于循環體)
continue [n]:提前結束第n層的本輪循環,而直接進入下一輪判斷;
break [n]:提前結束循環;
function函數
語法一:
function f_name {
函數體。。。
}
語法二:
f_name () {
函數體。。。
}
bash腳本編程:
變量:存儲單個元素的內存空間;
數組:存儲多個元素的連續的內存空間;
數組名
索引:編號從0開始,屬于數值索引;注意:索引也可以使用自定義的格式,而不僅僅是數值格式;
bash的數組支持稀疏格式;
引用數組中的元素:${ARRAY_NAME[INDEX]}
數組長度(數組中元素的個數):
${#ARRAY_NAME[*]}、${#ARRAY_NAME[@]}
引用所有元素
${ARRAY_NAME[*]}、${ARRAY_NAME[@]}
取出特定元素:數組切片
${ARRAY_NAME[@]:offset:number}
offset:要跳過的元素個數
number:要取出的元素個數;去偏移量之后的所有元素:${ARRAY_NAME[@]:offset};
聲明數組:
declare -a ARRAY_NAME
declare -A ARRAY_NAME:關聯數組:
數組元素的賦值方式:
(1)一次只賦值一個元素:
ARRAY_NAME[INDEX]=VALUE
(2)一次賦值全部元素:
ARRAY_NAME=(“VALUE1” “VALUE2″ …)
(3)只賦值特定元素:
ARRAY_NAME=([0]=”VALUE1″ [3]=”VALUE3” …)
(4)讓用戶輸入元素
read -a ARRAY
例子:隨機生產10個數保存于數組中,找出最大和最小值;
declare -a nums
declare -i max=0
declare -i min=0
for i in {0..9};do
nums[$i]=$RANDOM
echo ${nums[$i]}
if [ $i -eq 0 ];then
min=${nums[$i]}
max=${nums[$i]}
else
if [ ${nums[$i]} -gt $max ];then
max=${nums[$i]}
fi
if [ ${nums[$i]} -lt $min ];then
min=${nums[$i]}
fi
fi
done
echo “max: $max”
echo “min: $min”
向數組中追加元素:ARRAY[${#ARRAY[*]}]
刪除數組中的某元素:unset ARRAY[INDEX]
關聯數組:
declare -a ARRAY_NAME
ARRAY_NAME=([index_name1]=”VALUE1″ ? ? [index_name2]=”VALUE2″ ? ?…)
bash的字符串處理工具:
字符串切片:
${var:offset:number}:
offset:要跳過的字符串個數
number:要取出的字符串個數;去偏移量之后的所有字符串:${ARRAY_NAME[@]:offset};
取字符串的最右側幾個字符:${var: ?-lengh};注意冒號后面必須有一空白字符;
基于模式去子串:
${var#*word}:其中word可以是指定的任意字符;功能:自左而右,查找var變量所存儲的字符串中,第一次出現的word,刪除字符串開頭至第一次出現word字符之間的所有字符;
${var##*word}:其中word可以是指定的任意字符;功能:自左而右,查找var變量所存儲的字符串中,最后一次出現的word,刪除字符串開頭至最后一次出現word字符之間的所有字符;
${var%word*}:其中word可以是指定的任意字符;功能:自右而左,查找var變量所存儲的字符串中,第一次出現的word,刪除字符串最后一個字符向左至第一次出現word字符之間的所有字符;
${var%word*}:其中word可以是指定的任意字符;功能:自右而左,查找var變量所存儲的字符串中,第一次出現的word,刪除字符串最后一個字符向左至最后一次出現word字符之間的所有字符;
例子:url=http://www.lewis.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}:查找var所表示的字符串中,所有被pattern所匹配到的字符串,刪除之。
${var/#pattern}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,刪除之。
${var/%pattern}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,刪除之。
字符大小寫轉換:
${var^^}:把var中的所有小寫字母轉換成大寫;
${var,,}:把var中的所有大小字母轉換成小寫;
變量賦值:
${var:-value}:如果var為空或未設置,那么返回value;否則,則返回var的值;
${var:=value}:如果var為空或未設置,那么返回value,并將value賦值給var;否則,則返回var的值;
${var:+value}:如果var非空,則返回value;
${var:?error_info}:如果var為空或未設置,那么返回error_info;否則,則返回var的值;
為腳本程序使用配置文件:
定義文本文件,每行定義“name=value”
在腳本中source此文件即可
mktemp命令:創建臨時文件或目錄
-d:創建臨時目錄
–tmpdir:指明臨時文件目錄位置
例子:mktemp /tmp/test.XXX
install命令:功用類似cp命令
install [OPTION]… [-T] SOURCE DEST
install [OPTION]… SOURCE… DIRECTORY
install [OPTION]… -t DIRECTORY SOURCE…
install [OPTION]… -d DIRECTORY…
-m MODE:指明權限
-o OWNER:指明屬主
-g GROUP:指明屬組
ldd:查找某命令文件所依賴的共享庫
ldd [OPTION]… FILE…
練習:寫一個腳本
(1)提示用戶輸入一個可執行命令名稱;
(2)獲取此命令所依賴到的所有庫文件列表;
(3)復制命令至某目錄(例如/mnt/sysroot)下的對應路徑下;
(4)復制此命令依賴到的所有庫文件至目標目錄下的對應路徑下;
進一步:每次復制完成一個命令后,不要退出,而是提示用戶鍵入新的要復制的命令,并重復完成完成上述功能:直到用戶輸入quit退出;
本文來自投稿,不代表Linux運維部落立場,如若轉載,請注明出處:http://www.www58058.com/92777