Linux shell知識點匯總_linux shell

來源:互聯網
上載者:User

實際上Shell是一個命令直譯器,它解釋由使用者輸入的命令並且把它們送到核心。不僅如此,Shell有自己的程式設計語言用於對命令的編輯,它允許使用者編寫由shell命令組成的程式。Shell程式設計語言具有普通程式設計語言的很多特點,比如它也有迴圈結構和分支控制結構等,用這種程式設計語言編寫的Shell程式與其他應用程式具有同樣的效果。

引言

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]$

shell中的大小比較

#第一種(())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 燕睿濤

可以看到上面這幾種還是有些規律的:

雙小括弧[(())]裡面是可以直接使用大於小於符號進行比較(>、<、<=、>=),而且不需要“坑爹”的空格,用於數學計算
單中括弧([])裡面比較必須使用-gt、-lt、-ne、-eq這些運算子,而且必須要有嚴格的空格要求
雙中括弧([[]])裡面比較可以使用>、<、-gt、-lt......這兩種格式,但是還是必須要有嚴格的空格要求,而且雙中括弧中的>、<對類似於字串的比較,所以在使用的時候需要注意

shell中的括弧

#看看小括弧的用法,首先是在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 ))...  #(())雙小括弧使用&& 

shell中函數的定義

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  

函數的整體形式如上面的例子,這裡面注意兩點:

首先就是傳回值,通過return的傳回值只能是整數,並且在調用完成之後使用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 #終止當前前台的進程

以上所述就是本文的全部內容了,希望能夠對大家熟悉Linux shell命令有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.