tft每日頭條

 > 生活

 > shell 注釋規範

shell 注釋規範

生活 更新时间:2024-12-05 11:20:13

shell 注釋規範?if ($i<5) if [ $i -lt 5 ] if [ $a -ne 1 -a $a != 2 ] if [ $a -ne 1] && [ $a != 2 ] if [[ $a != 1 && $a != 2 ]] for i in $(seq 0 4);do echo $i;done for i in `seq 0 4`;do echo $i;done for ((i=0;i<5;i ));do echo $i;done for i in {0..4};do echo $i;done ,我來為大家科普一下關于shell 注釋規範?下面希望有你要的答案,我們一起來看看吧!

shell 注釋規範(中各種括号的作用)1

shell 注釋規範

一、小括号,圓括号 ()1、單小括号 ()
  • 命令組。括号中的命令将會新開一個子shell順序執行,所以括号中的變量不能夠被腳本餘下的部分使用。括号中多個命令之間用分号隔開,最後一個命令可以沒有分号,各命令和括号之間不必有空格。
  • 命令替換。等同于`cmd`,shell掃描一遍命令行,發現了$(cmd)結構,便将$(cmd)中的cmd執行一次,得到其标準輸出,再将此輸出放到原來命令。有些shell不支持,如tcsh。
  • 用于初始化數組。如:array=(a b c d)
2、雙小括号 (( ))
  • 整數擴展。這種擴展計算是整數型的計算,不支持浮點型。((exp))結構擴展并計算一個算術表達式的值,如果表達式的結果為0,那麼返回的退出狀态碼為1,或者 是"假",而一個非零值的表達式所返回的退出狀态碼将為0,或者是"true"。若是邏輯判斷,表達式exp為真則為1,假則為0。
  • 隻要括号中的運算符、表達式符合C語言運算規則,都可用在$((exp))中,甚至是三目運算符。作不同進位(如二進制、八進制、十六進制)運算時,輸出結果全都自動轉化成了十進制。如:echo $((16#5f)) 結果為95 (16進位轉十進制)
  • 單純用 (( )) 也可重定義變量值,比如 a=5; ((a )) 可将 $a 重定義為6
  • 常用于算術運算比較,雙括号中的變量可以不使用$符号前綴。括号内支持多個表達式用逗号分開。 隻要括号中的表達式符合C語言運算規則,比如可以直接使用for((i=0;i<5;i )), 如果不使用雙括号, 則為for i in `seq 0 4`或者for i in {0..4}。再如可以直接使用if (($i<5)), 如果不使用雙括号, 則為if [ $i -lt 5 ]。
二、中括号,方括号[]1、單中括号 []
  • Bash 的内部命令,[和Test是等同的。如果我們不用絕對路徑指明,通常我們用的都是bash自帶的命令。if/test結構中的左中括号是調用test的命令标識,右中括号是關閉條件判斷的。這個命令把它的參數作為比較表達式或者作為文件測試,并且根據比較的結果來返回一個退出狀态碼。if/test結構中并不是必須右中括号,但是新版的Bash中要求必須這樣。
  • Test和[]中可用的比較運算符隻有==和!=,兩者都是用于字符串比較的,不可用于整數比較,整數比較隻能使用-eq,-gt這種形式。無論是字符串比較還是整數比較都不支持大于号小于号。如果實在想用,對于字符串比較可以使用轉義形式,如果比較"ab"和"bc":[ ab \< bc ],結果為真,也就是返回狀态為0。[ ]中的邏輯與和邏輯或使用-a 和-o 表示。
  • 字符範圍。用作正則表達式的一部分,描述一個匹配的字符範圍。作為test用途的中括号内不能使用正則。
  • 在一個array 結構的上下文中,中括号用來引用數組中每個元素的編号。
2、雙中括号[[ ]]
  • [[是 bash 程序語言的關鍵字。并不是一個命令,[[ ]] 結構比[ ]結構更加通用。在[[和]]之間所有的字符都不會發生文件名擴展或者單詞分割,但是會發生參數擴展和命令替換。
  • 支持字符串的模式匹配,使用=~操作符時甚至支持shell的正則表達式。字符串比較時可以把右邊的作為一個模式,而不僅僅是一個字符串,比如[[ hello == hell? ]],結果為真。[[ ]] 中匹配字符串或通配符,不需要引号。
  • 使用[[ ... ]]條件判斷結構,而不是[ ... ],能夠防止腳本中的許多邏輯錯誤。比如,&&、||、<和> 操作符能夠正常存在于[[ ]]條件判斷結構中,但是如果出現在[ ]結構中的話,會報錯。比如可以直接使用if [[ $a != 1 && $a != 2 ]], 如果不适用雙括号, 則為if [ $a -ne 1] && [ $a != 2 ]或者if [ $a -ne 1 -a $a != 2 ]。
  • bash把雙中括号中的表達式看作一個單獨的元素,并返回一個退出狀态碼。。

if ($i<5) if [ $i -lt 5 ] if [ $a -ne 1 -a $a != 2 ] if [ $a -ne 1] && [ $a != 2 ] if [[ $a != 1 && $a != 2 ]] for i in $(seq 0 4);do echo $i;done for i in `seq 0 4`;do echo $i;done for ((i=0;i<5;i ));do echo $i;done for i in {0..4};do echo $i;done

三、大括号、花括号 {}1、常規用法

(1) 大括号拓展。(通配(globbing))将對大括号中的文件名做擴展。在大括号中,不允許有空白,除非這個空白被引用或轉義。第一種:對大括号中的以逗号分割的文件列表進行拓展。如 touch {a,b}.txt 結果為a.txt b.txt。第二種:對大括号中以點點(..)分割的順序文件列表起拓展作用,如:touch {a..d}.txt 結果為a.txt b.txt c.txt d.txt

# ls {ex1,ex2}.sh ex1.sh ex2.sh # ls {ex{1..3},ex4}.sh ex1.sh ex2.sh ex3.sh ex4.sh # ls {ex[1-3],ex4}.sh ex1.sh ex2.sh ex3.sh ex4.sh

(2) 代碼塊,又被稱為内部組,這個結構事實上創建了一個匿名函數 。與小括号中的命令不同,大括号内的命令不會新開一個子shell運行,即腳本餘下部分仍可使用括号内變量。括号内的命令間用分号隔開,最後一個也必須有分号。{}的第一個命令和左括号之間必須要有一個空格。

2、幾種特殊的替換結構

${var:-string} ${var: string} ${var:=string} ${var:?string}

1、${var:-string}和${var:=string}:若變量var為空,則用在命令行中用string來替換${var:-string},否則變量var不為空時,則用變量var的值來替換${var:-string};對于${var:=string}的替換規則和${var:-string}是一樣的,所不同之處是${var:=string}若var為空時,用string替換${var:=string}的同時,把string賦給變量var: ${var:=string}很常用的一種用法是,判斷某個變量是否賦值,沒有的話則給它賦上一個默認值。

2、${var: string}的替換規則和上面的相反,即隻有當var不是空的時候才替換成string,若var為空時則不替換或者說是替換成變量 var的值,即空值。(因為變量var此時為空,所以這兩種說法是等價的)

3、{var:?string}替換規則為:若變量var不為空,則用變量var的值來替換${var:?string};若變量var為空,則把string輸出到标準錯誤中,并從腳本中退出。我們可利用此特性來檢查是否設置了變量的值。

補充擴展:在上面這五種替換結構中string不一定是常值的,可用另外一個變量的值或是一種命令的輸出。

3、四種模式匹配替換結構

模式匹配記憶方法:

# 是去掉左邊(在鍵盤上#在$之左邊) % 是去掉右邊(在鍵盤上%在$之右邊)

#和%中的單一符号是最小匹配,兩個相同符号是最大匹配。

${var%pattern} ${var%%pattern ${var#pattern} ${var##pattern}

  • 第一種模式:${variable%pattern},這種模式時,shell在variable中查找,看它是否一給的模式pattern結尾,如果是,就從命令行把variable中的内容去掉右邊最短的匹配模式
  • 第二種模式: ${variable%%pattern},這種模式時,shell在variable中查找,看它是否一給的模式pattern結尾,如果是,就從命令行把variable中的内容去掉右邊最長的匹配模式
  • 第三種模式:${variable#pattern} 這種模式時,shell在variable中查找,看它是否一給的模式pattern開始,如果是,就從命令行把variable中的内容去掉左邊最短的匹配模式
  • 第四種模式: ${variable##pattern} 這種模式時,shell在variable中查找,看它是否一給的模式pattern結尾,如果是,就從命令行把variable中的内容去掉右邊最長的匹配模式
  • 這四種模式中都不會改變variable的值,其中,隻有在pattern中使用了*匹配符号時,%和%%,#和##才有區别。結構中的pattern支持通配符,*表示零個或多個任意字符,?表示僅與一個任意字符匹配,[...]表示匹配中括号裡面的字符,[!...]表示不匹配中括号裡面的字符。

# var=testcase # echo $var testcase # echo ${var%s*e} testca # echo $var testcase # echo ${var%%s*e} te # echo ${var#?e} stcase # echo ${var##?e} stcase # echo ${var##*e} # echo ${var##*s} e # echo ${var##test} case

4、字符串提取和替換

${var:num} ${var:num1:num2} ${var/pattern/pattern} ${var//pattern/pattern}

  • 第一種模式:${var:num},這種模式時,shell在var中提取第num個字符到末尾的所有字符。若num為正數,從左邊0處開始;若num為負數,從右邊開始提取字串,但必須使用在冒号後面加空格或一個數字或整個num加上括号,如${var: -2}、${var:1-3}或${var:(-2)}。
  • 第二種模式:${var:num1:num2},num1是位置,num2是長度。表示從$var字符串的第$num1個位置開始提取長度為$num2的子串。不能為負數。
  • 第三種模式:${var/pattern/pattern}表示将var字符串的第一個匹配的pattern替換為另一個pattern。
  • 第四種模式:${var//pattern/pattern}表示将var字符串中的所有能匹配的pattern替換為另一個pattern。

[root@centos ~]# var=/home/centos [root@centos ~]# echo $var /home/centos [root@centos ~]# echo ${var:5} /centos [root@centos ~]# echo ${var: -6} centos [root@centos ~]# echo ${var:(-6)} centos [root@centos ~]# echo ${var:1:4} home [root@centos ~]# echo ${var/o/h} /hhme/centos [root@centos ~]# echo ${var//o/h} /hhme/cenths


四、符号$後的括号
  • (1)${a} 變量a的值, 在不引起歧義的情況下可以省略大括号。
  • (2)$(cmd) 命令替換,和`cmd`效果相同,結果為shell命令cmd的輸,過某些Shell版本不支持$()形式的命令替換, 如tcsh。
  • (3)$((expression)) 和`exprexpression`效果相同, 計算數學表達式exp的數值, 其中exp隻要符合C語言的運算規則即可, 甚至三目運算符和邏輯表達式都可以計算。

五、使用
  • 1、多條命令執行
    • (1)單小括号,(cmd1;cmd2;cmd3) 新開一個子shell順序執行命令cmd1,cmd2,cmd3, 各命令之間用分号隔開, 最後一個命令後可以沒有分号。
    • (2)單大括号,{ cmd1;cmd2;cmd3;} 在當前shell順序執行命令cmd1,cmd2,cmd3, 各命令之間用分号隔開, 最後一個命令後必須有分号, 第一條命令和左括号之間必須用空格隔開。
  • {}() 而言, 括号中的重定向符隻影響該條命令, 而括号外的重定向符影響到括号中的所有命令。
,

更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!

查看全部

相关生活资讯推荐

热门生活资讯推荐

网友关注

Copyright 2023-2024 - www.tftnews.com All Rights Reserved