shell中的數組
雜項知識點
參考文獻
SHELL在處理一些問題的時候有得天獨厚的優勢,快捷方便,學會了還可以顯擺顯擺,當然了,shell的語法有點坑爹,沒有系統的學過,只能一點一點的積累。
今天這個是在實現一個刷新數據庫數據的腳本的時候碰到的一些知識點,刷新的時候用到了正則匹配、數學運算、比較等等。
arr=(1 2 3 4 5)arr=(燕睿濤 yrt lulu yanruitao)arr=('^[0-9]+$' '^yrt/.(/d+)/.log$')arr=("燕睿濤" / "yanruitao" / "today is a good day!")數組的使用len=${#arr[@]}#返回的是數組元素的個數echo ${arr[0]}#數組中的第一個元素,這個和其他語言的數組類似,下表從0開始echo ${arr[2]}#數組中的第3個元素實際的例子[yanruitao@boss_runtime sh]$ arr=(> "燕睿濤"> "http:////www/.baidu/.com//(/d+)/.html"> "yanruitao"> "lulu"> "yrt"> )[yanruitao@boss_runtime sh]$ echo ${#arr[@]}5[yanruitao@boss_runtime sh]$ echo ${arr[1]}http:////www/.baidu/.com//(/d+)/.html[yanruitao@boss_runtime sh]$ echo ${arr[0]}燕睿濤[yanruitao@boss_runtime sh]$ echo ${arr[5]}[yanruitao@boss_runtime sh]$#第一種(())if((6 <8)); then echo "yes 燕睿濤"; fi#輸出——yes 燕睿濤if(($a>8)); then echo "yes 燕睿濤"; fiif(($a<=$b)); then echo "yes 燕睿濤"; fi#第二種[] [[]]if [ 2 -gt 1 ]; then echo "iforever 燕睿濤"; fiif [[ 'abc' > 'ab' ]]; then echo "iforever 燕睿濤"; fi#iforever 燕睿濤if [[ 2 < 10 ]]; then echo "iforever 燕睿濤"; fi#無輸出if [[ 2 -lt 10 ]]; then echo "iforever 燕睿濤"; fi#iforever 燕睿濤可以看到上面這幾種還是有些規律的:
#看看小括號的用法,首先是在for循環里面,相當于還是數學計算[yanruitao@boss_runtime ad]$ for((a=0;a<10;a++))> do> echo $a> done0123456789#對變量進行++,還是相當于數序運算[yanruitao@boss_runtime ad]$ i=1[yanruitao@boss_runtime ad]$ echo $i1[yanruitao@boss_runtime ad]$ let i++[yanruitao@boss_runtime ad]$ echo $i2[yanruitao@boss_runtime ad]$ ((i++))[yanruitao@boss_runtime ad]$ echo $i3#數學運算[yanruitao@boss_runtime ad]$ echo 1+21+2[yanruitao@boss_runtime ad]$ echo $((1+2))3#單括號里面是一個命令組,括號中的命令將會新開一個shell順序執行,所以這個里面相當于一個封閉的空間,里面的變量什么的不能被剩余代碼使用[yanruitao@boss_runtime ad]$ a=1[yanruitao@boss_runtime ad]$ (a=3;echo $a)3[yanruitao@boss_runtime ad]$ echo $a1#括號中and的使用if [[ -n "$ret" && $ret -gt 123 ]]...#[[]]雙中括號中只能使用&&,不能使用-aif [ -n "$ret" -a $ret -gt 123 ]...#[]單中括號中只能使用-a,不能使用&&if(($ret)) && (($ret >123 ))...#(())雙小括號使用&&function getId(){local url=$1#local限定了變量url的作用域只在函數里面,不然會污染全局的作用域 ereg="http:////www/.baidu/.com///([0-9]/+/)/.html" local ret=$(exPR $url : $ereg) if [[ -n "$ret" && $ret -gt 0 ]]; then#當ret為null時使用[]會報錯,-n這里的雙引號一定要加上,不然當$ret為null時,一直返回真 echo $ret return 0 fi return 1}[yanruitao@boss_runtime sh]$ echo $?0[yanruitao@boss_runtime sh]$ getId "http://www.baidu.com/123.htl"[yanruitao@boss_runtime sh]$ echo $?1[yanruitao@boss_runtime sh]$ getId "http://www.baidu.com/123.html"123[yanruitao@boss_runtime sh]$ echo $?0 函數的整體形式如上面的例子,這里面注意兩點:
echo $?可以查看返回值。echo,就像ret=$(getId "http://www.baidu.com.1234.html"),只有echo的值會傳遞給ret變量。[yanruitao@boss_runtime sh]$ str="燕睿濤 lulu yrt yanruitao"[yanruitao@boss_runtime sh]$ arr=($str)#這一步將字符串轉化為了數組[yanruitao@boss_runtime sh]$ echo ${arr[*]}燕睿濤 lulu yrt yanruitao[yanruitao@boss_runtime sh]$ echo ${#arr[@]}4常用判斷標志[ -z STRING ] “STRING” 的長度為零則為真。 [ -n STRING ] or [ STRING ] “STRING” 的長度為非零 non-zero則為真。[ -d FILE ] 如果 FILE 存在且是一個目錄則為真。[ -a FILE ] 如果 FILE 存在則為真。linux后臺運行相關& #在一個命令的最后加上這個命令,可以將該命令放到后臺執行./update.sh 100 500 &ctrl + z#講一個正在前臺執行的命令放到后臺,并且處于暫停狀態jobs#查看當前后臺運行的命令jobs -l#可以顯示所有后臺任務的PID[yanruitao@boss_runtime sh]$ jobs -l[1] 9681 Running ./t.sh 100 300 &[2] 9683 Running ./t.sh 100 300 &[3]- 9685 Running ./t.sh 100 300 &[4]+ 9688 Running ./t.sh 100 300 &fg #把后臺中的命令調至前臺繼續運行,如果后臺有多個命令可以使用`fg %jobnumber`將選中命令調出[yanruitao@boss_runtime sh]$ jobs -l[2] 10033 Running ./t.sh 100 300 &[3] 10035 Running ./t.sh 100 300 &[4]- 10037 Running ./t.sh 100 300 &[5]+ 10039 Running ./t.sh 100 300 &[yanruitao@boss_runtime sh]$ fg %2./t.sh 100 300 bg #講一個在后臺暫停的命令變成在后臺繼續執行。同樣,如果有多個命令,可以使用bg %jobnumber[yanruitao@boss_runtime sh]$ jobs -l[1]- 11655 Running ./t.sh 100 300 &[2]+ 11662 Running ./t.sh 100 300 &[yanruitao@boss_runtime sh]$ fg %1./t.sh 100 300^Z[1]+ Stopped ./t.sh 100 300[yanruitao@boss_runtime sh]$ jobs -l[1]+ 11655 Stopped ./t.sh 100 300[2]- 11662 Running ./t.sh 100 300 &[yanruitao@boss_runtime sh]$ bg %1[1]+ ./t.sh 100 300 &[yanruitao@boss_runtime sh]$ jobs -l[1]- 11655 Running ./t.sh 100 300 &[2]+ 11662 Running ./t.sh 100 300 &kill#終止進程kill %num#通過jobs查看的job號,進行殺死kill pid #通過進程號殺掉進程ctrl + C #終止當前前臺的進程AWKawk是強大的文本處理工具。
$awk -F ':' 'BEGIN {count=0;print "[start]user count is ", count} {count=count+1;print $1,"=>",$7;} END{print "[end]user count is ", count}' /etc/passwd-F參數指定的是分隔符,對每一分行數據按照他所指定的符號進行分割,默認是空格。{}之間的內容。很常用的一個操作:
dirname="$(dirname $path)"; //獲取目標文件所在的目錄ls "$dirname" 1>/dev/null 2>&1 || mkdir -p "$dirname"; 重命名命令有時有需要將一個很長的命令(拼起來的目錄)縮短,這個時候可以使用下面的方法:
shopt -s expand_aliases; //打開expand_aliases設置,可以進行重命名操作alias log_echo='echo $1'; //設置log_echo 為echo $1的別名,就可以像函數一樣使用log_echolog_echo 燕睿濤; //輸出燕睿濤log_echo='eval echo $1';$log_echo 燕睿濤; //輸出燕睿濤動態顯示進度條shell下面安裝軟件的時候經常會看到那種動態的進度條什么的,感覺很高大上,其實很好實現,用到了tput命令,下面看個例子:
#!/bin/bashfor i in 1 2 3 4 5 6 7 8 9 10do tput sc;#保存當前光標位置 tput dl1; #刪除光標所在函數數據,dl后面的數字是刪除的行數 echo -n "loading $i/10"; #不換行的輸出雙引號的內容 tput rc;#光標回到上次sc(save cursor position)保存的位置 sleep 2;done;看看效果:
微信號: love_skills
越努力,越幸運!越幸運,越努力!
做上CEO不是夢
贏取白富美不是夢
屌絲逆襲不是夢
就是現在!!加油
新聞熱點
疑難解答