數組
變量:存儲單個元素的內存空間
數組:存儲多個元素的連續的內存空間,相當于多個變量的集合
數組名和索引
索引:編號從0開始,屬于數值索引
注意:索引可支持使用自定義的格式,而不僅是數值格式,即為關聯索引
bash4.0版本之后開始支持
bash –version?? 查看bash版本
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 ???????????????????????????????—不支持管道
顯示所有數組:declare -a
引用數組元素:
${ARRAY_NAME[INDEX]} ???????????????${ 數組名[下標]}
echo ${title[0]}???????????????????? 顯示數組元素title[0]
注意:省略[INDEX]表示引用下標為0的元素
引用數組所有元素:
${ARRAY_NAME[*]}
${ARRAY_NAME[@]}
數組的長度(數組中元素的個數):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
隨機數組成的數組比較最大值最小值:冒泡算法
declare -a rand
for ((i=0;i<9;i++));do
rand[$i]=$RANDOM
if [ $i -eq 0 ];then
max=${rand[$i]}
min=$max
else
[ $max -lt ${rand[$i]} ] && max=${rand[$i]}
[ $min -gt ${rand[$i]} ] && min=${rand[$i]}
fi
done
echo all is ${rand[*]}
echo max is $max
echo min is $min
刪除數組中的某元素:導致稀疏格式
unset ARRAY[INDEX]
刪除整個數組:
unset ARRAY
如果數組是連續的數組的個數為n echo ${#name[*]}那么最后一個數組的下標為n-1
數組如果再循環中 :循環結束數組就結束了
管道傳給循環開啟子shell了
寫入腳本不好使(腳本開啟了子shell)
df -h|grep “/dev/sd”>df.log
腳本數組元素為var/log下.log結尾的文件 所有下標為偶數的文件中的內容行數之和
declare -a file
file=(/var/log/*.log)
declare -i a=0
for i in $(seq 0 $[${#file[*]}-1]);do
if [ $[$i%2] -eq 0 ];then
let a=$a+$(cat ${file[$i]}|wc -l)
fi
done
echo “lines $a”
字符串切片
${#var}:返回字符串變量var的長度 ????????(查看字符串的長度var可以是數組的名稱者?????? 變量)
${var:offset}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字 符開始,到最后的部分,offset的取值在0 到 ${#var}-1 之間(bash4.2后,允許為負值)
${var:offset:number}:返回字符串變量var中從第offset個字符后(不包括第offset個 字符)的字符開始,長度為number的部分
${var: -length}:取字符串的最右側幾個字符
注意:冒號后必須有一空白字符
${var:offset:-length}:從最左側跳過offset字符,一直向右取到距離最右側lengh個字 符之前的內容
${var: -length:-offset}:先從最右側向左取到length個字符開始,再向右取到距離最 右側offset個字符之間的內容
注意:-length前空格 ???版本 (7可以用6不能)
從左到右
基于模式取字符串
${var#*word}:其中word可以是指定的任意字符
功能:自左而右,查找var變量所存儲的字符串中,第一次出現的word, 刪 除字符串開頭至第一次出現word字符之間的所有字符
${var##*word}:同上,貪婪模式,不同的是,刪除的是字符串開頭至最后 一次由word指定的字符之間的所有內容
示例: file=“var/log/messages”
${file#*/}: log/messages
${file##*/}: messages
從右往左
${var%word*}:其中word可以是指定的任意字符
功能:自右而左,查找var變量所存儲的字符串中,第一次出現的word, 刪 除字符串最后一個字符向左至第一次出現word字符之間的所有字符 file=”/var/log/messages”
${file%/*}: /var/log
${var%%word*}:同上,只不過刪除字符串最右側的字符向左至最后一次出現 word字符之間的所有字符;
查找替換
${var/pattern/substr}:查找var所表示的字符串中,第一次被pattern所匹 配到的字符串,以substr替換之
${var//pattern/substr}: 查找var所表示的字符串中,所有能被pattern所匹 配到的字符串,以substr替換之
${var/#pattern/substr}:查找var所表示的字符串中,行首被pattern所匹 配到的字符串,以substr替換之
${var/%pattern/substr}:查找var所表示的字符串中,行尾被pattern所匹 配到的字符串,以substr替換之
查找并刪除 ?(替代的為空)
${var/pattern}:刪除var所表示的字符串中第一次被pattern所匹配到的字符串 ${var//pattern}:刪除var所表示的字符串中所有被pattern所匹配到的字符串 ${var/#pattern}:刪除var所表示的字符串中所有以pattern為行首所匹配到的 字符串
${var/%pattern}:刪除var所表示的字符串中所有以pattern為行尾所匹配到的 字符串
字符大小寫轉換
${var^^}:把var中的所有小寫字母轉換為大寫
${var,,}:把var中的所有大寫字母轉換為小寫
變量賦值 ???????????????????????????????????????????:相當于吧str為空字符串當做str沒有配置
高級變量
Shell變量一般是無類型的,但是bash Shell提供了declare和typeset兩個命令 用于指定變量的類型,兩個命令是等價的
declare [選項] 變量名 ????????????????????????????和typeset等價
-r 聲明或顯示只讀變量
-i 將變量定義為整型數
-a 將變量定義為數組
-A 將變量定義為關聯數組
-f 顯示已定義的所有函數名及其內容
-F 僅顯示已定義的所有函數名
-x 聲明或顯示環境變量和函數
-l 聲明變量為小寫字母 declare –l var=UPPER
-u 聲明變量為大寫字母 declare –u var=lower
eval命令將會首先掃描命令行進行所有的置換,然后再執行該命令。該命令適用于 那些一次掃描無法實現其功能的變量.該命令對變量進行兩次掃描
間接變量引用
如果第一個變量的值是第二個變量的名字,從第一個變量引用第二個變量的值 就稱為間接變量引用
variable1的值是variable2,而variable2又是變量名,variable2的值為value, 間接變量引用是指通過variable1獲得變量值value的行為
variable1=variable2
variable2=value
bash Shell提供了兩種格式實現間接變量引用
eval tempvar=\$$variable1
示例:eval echo \$$name?????????? —eval echo $`echo $name`
tempvar=${!variable1}
命令存到一個變量里不是寫死的
mktemp命令:創建并顯示臨時文件,可避免沖突 ???????— 一般放到變量里使用
mktemp [OPTION]… [TEMPLATE]
TEMPLATE: filenameXXX
X至少要出現三個 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?????? 組
示例:
install -m 700 -o wang -g admins srcfile desfile
install –m 770 –d /testdir/installdir
復制/etc/shadow文件 到/data/下改名為password.txt 并吧權限設置為700所有者設置為wang所有組為bin
mkdir創建是設置權限
expect 是由Don Libes基于Tcl( Tool Command Language )語言開發的, 主要應用于自動化交互式操作的場景,借助Expect處理交互的命令,可以將交互 過程如:ssh登錄,ftp登錄等寫在一個腳本上,使之自動化完成。尤其適用于需 要對多臺服務器執行相同操作的環境中,可以大大提高系統管理人員的工作效率
expect 語法:
expect [選項] [ -c cmds ] [ [ -[f|b] ] cmdfile ] [ args ]
選項
-c:從命令行執行expect腳本,默認expect是交互地執行的
示例:expect -c ‘expect “\n” {send “pressed enter\n”} ???期望收到回車\n???? 收到就send “pressed enter\n”
-d:可以輸出輸出調試信息
示例:expect -d ssh.exp
expect中相關命令
spawn:啟動新的進程
send:用于向進程發送字符串
expect:從進程接收字符串
interact:允許用戶交互
exp_continue 匹配多個字符串在執行動作后加此命令
單一分支模式語法:
expect “hi” {send “You said hi\n”}
匹配到hi后,會輸出“you said hi”,并換行
多分支模式語法:
expect “hi” { send “You said hi\n” } \
“hehe” { send “Hehe yourself\n” } \
“bye” { send “Good bye\n” }
匹配hi,hello,bye任意字符串時,執行相應輸出。等同如下:
expect {
“hi” { send “You said hi\n”}
“hehe” { send “Hehe yourself\n”}
“bye” { send “Good bye\n”} }
示例
#!/usr/bin/expect ?????????????????????????????—首棒機制不是bash,expect是一種語言
spawn scp /etc/fstab 192.168.8.100:/app ?????????—spawn激活后面的命令
expect {
“yes/no” { send “yes\n”;exp_continue }???? ?— 捕獲yes/no就向命令發送yes exp_contimue表示繼續執行捕獲
“password” { send “magedu\n” } ???????—捕獲到password 就向命令發送magedu
}
expect eof ?????????????????????????—結束代碼
如果執行比較慢就vim /etc/ssh/sshd_config
把ssh服務 的GSSAPIAuthentication yes?????????????????? yes改為no
#UseDNS no???????????????????? 啟用(去掉#)
改完后重啟sshd服務systemctl restart sshd
實現自動登錄后繼續交互
#!/usr/bin/expect
spawn ssh wang@192.168.147.69
expect {
“yes/no” { send “yes\n”;exp_continue }
“password” { send “magedu\n” }
}
interact ?????????????????????????——繼續交互
#expect eof
#!/usr/bin/expect
set ip 192.168.8.100 ?????????????變量ip賦值為192.168.2.100
set user root ?????????????????????????變量user賦值為root
set password magedu ???????變量password賦值為magedu
set timeout 10 ???????????????超時時長10秒
spawn ssh $user@$ip ???????????啟用連個變量
expect {
“yes/no” { send “yes\n”;exp_continue }
“password” { send “$password\n” }
}
interact
#!/usr/bin/expect
set ip [lindex $argv 0] ???????????第一個位置參數 [lindex $argv 0]
set user [lindex $argv 1] ?????????第二個
set password [lindex $argv 2] ?????第三個
spawn ssh $user@$ip
expect {
“yes/no” { send “yes\n”;exp_continue }
“password” { send “$password\n” }
}
interact
#./ssh3.exp 192.168.8.100 root magedu ???????注釋語法
本文來自投稿,不代表Linux運維部落立場,如若轉載,請注明出處:http://www.www58058.com/98390