1.操作符(let 標(biāo)志符)
+ 加法
- 減法
* 乘法
/ 除法
** 冪運算
3 let "z=5**3"
% 取模
bash$ expr 5 % 3
2.比較符 (注意[ ]和變量之間需要空格" ")
整型比較符
-eq 等于,如:if [ "$a" -eq "$b" ] //注意空格
-ne 不等于,如:if [ "$a" -ne "$b" ]
-gt 大于,如:if [ "$a" -gt "$b" ]
-ge 大于等于,如:if [ "$a" -ge "$b" ]
-lt 小于,如:if [ "$a" -lt "$b" ]
-le 小于等于,如:if [ "$a" -le "$b" ]
小于(需要雙括號),如:(("$a" "$b"))
= 小于等于(需要雙括號),如:(("$a" = "$b"))
> 大于(需要雙括號),如:(("$a" > "$b"))
>= 大于等于(需要雙括號),如:(("$a" >= "$b"))
字符串比較
= 等于,如:if [ "$a" = "$b" ]
== 等于,如:if [ "$a" == "$b" ],與=等價
注意:==的功能在[[]]和[]中的行為是不同的,如下:
1 [[ $a == z* ]] # 如果$a以"z"開頭(模式匹配)那么將為true
2 [[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么結(jié)果為true
3
4 [ $a == z* ] # File globbing 和word splitting將會發(fā)生
5 [ "$a" == "z*" ] # 如果$a等于z*(字符匹配),那么結(jié)果為true
一點解釋,關(guān)于File globbing是一種關(guān)于文件的速記法,比如"*.c"就是,再如~也是.但是file globbing并不是嚴(yán)格的正則表達(dá)式,雖然絕大多數(shù)情況下結(jié)構(gòu)比較像.
!= 不等于,如:if [ "$a" != "$b" ]
這個操作符將在[[]]結(jié)構(gòu)中使用模式匹配.
小于,在ASCII字母順序下.如:
if [[ "$a" "$b" ]]
if [ "$a" \ "$b" ]
注意:在[]結(jié)構(gòu)中""需要被轉(zhuǎn)義.
> 大于,在ASCII字母順序下.如:
if [[ "$a" > "$b" ]]
if [ "$a" \&; "$b" ]
注意:在[]結(jié)構(gòu)中">"需要被轉(zhuǎn)義.
具體參考Example 26-11來查看這個操作符應(yīng)用的例子.
-z 字符串為"null".就是長度為0.
-n 字符串不為"null"
注意:
使用-n在[]結(jié)構(gòu)中測試必須要用""把變量引起來.使用一個未被""的字符串來使用! -z
或者就是未用""引用的字符串本身,放到[]結(jié)構(gòu)中(見Example 7-6)雖然一般情況下可
以工作,但這是不安全的.習(xí)慣于使用""來測試字符串是一種好習(xí)慣.
3.eg
復(fù)制代碼 代碼如下:
#./bin/bash
#獲取英文月份對應(yīng)的數(shù)字月份
getmonthofenglish()
{
case "$1" in
"Jan") msg_month=1;;
"Feb") msg_month=2;;
"Mar") msg_month=3;;
"Apr") msg_month=4;;
"May") msg_month=5;;
"Jun") msg_month=6;;
"Jul") msg_month=7;;
"Aug") msg_month=8;;
"Sept") msg_month=9;;
"Oct") msg_month=10;;
"Nov") msg_month=11;;
"Dec") msg_month=12;;
esac
}
# 判斷是否有過期短信,有調(diào)用C刪除短信函數(shù)
del_overtime_sms()
{
num=`ipcs -q|grep "$1"|awk '{print $6}'`
if (( "$num" > "1" )); then
ipcs -q|grep "$1"|awk '{print $2,$6}'>overtimesms.ini
./del_overtime_sms //shell中調(diào)用C函數(shù)的結(jié)果
else
echo "消息隊列中沒有過期的短信"
fi
}
#獲取當(dāng)前月份對應(yīng)的天數(shù)
cd /mas/shell/zhangweiatest/clear_overtime_sms
mday=`./getmonthofday`
echo "當(dāng)前月份前一個月對應(yīng)的天數(shù)=$mday"
#獲取系統(tǒng)時間對應(yīng)的年,月
buff=`date|awk '{print $2,$3}'`
now_month=${buff:0:1}
now_day=${buff:3:1}
#獲取當(dāng)前隊列的存活時間
ipcs -qt|awk '{print $1,$3,$4}'>msglivelytime.ini
sed -n '4,$p' msglivelytime.ini >msglivelytime1.ini //獲取從第四行開始到結(jié)束的字符
mv msglivelytime1.ini msglivelytime.ini
while read msgid msg_month msg_day
do
echo
echo "消息隊列ID=$msgid創(chuàng)建的時間為:$msg_month月$msg_day日"
echo "系統(tǒng)時間為$now_month月的第$now_day天"
getmonthofenglish "$msg_month"
let "new_month = $msg_month + 1"
if [ "$msg_month" = "Not" ]; then //為空NULL
echo "隊列安全"
elif [ "$msg_month" = "" ]; then //空行
echo "NULL"
elif [ "$msg_month" = "$now_month" ]; then
let "msg_day1 = $msg_day + 2"
if (( "$now_day" >= "$msg_day1" )); then
if (( "$msg_day" "$mday" )); then
echo "消息隊列不安全"
del_overtime_sms "$msgid"
fi
fi
elif [ "$now_month" = "$new_month" ]; then
let "now_day1 = $now_day + $mday"
let "msg_day1 = $msg_day + 2"
echo "now_day1=$now_day1,msg_day1=$msg_day1"
if (( "$now_day1" >= "$msg_day1" )); then
# if (( "$msg_day1" "$mday" )); then
echo "消息隊列不安全"
del_overtime_sms "$msgid"
# fi
fi
elif (( "$now_month" > "$new_month" )); then
echo ""$msg_month" > "$now_month""
del_overtime_sms "$msgid"
echo "消息隊列不安全"
else
echo "msg queue safe"
fi
done msglivelytime.ini
在 shell 中的四則運算必須使用 expr 這個指令來輔助。因為這是一個指令,所以如果要將結(jié)果指定給變量,必須使用 ` 包起來。請注意,在 + - * / 的二邊都有空白,如果沒有空白將產(chǎn)生錯誤:
復(fù)制代碼 代碼如下:
$ expr 5 -2
3
$ sum=`expr 5 + 10`
$ echo $sum
15
$ sum=`expr $sum / 3`
$ echo $sum
5
還有一個要特別注意的是乘號 * 在用 expr 運算時,不可只寫 *。因為 * 有其它意義,所以要使用 \* 來代表。另外,也可以用 % 來求余數(shù)。
復(fù)制代碼 代碼如下:
$ count=`expr 5 \* 3`
$ echo $count
$ echo `expr $count % 3`
5
我們再列出更多使用 expr 指令的方式,下列表中為可以放在指令 expr 之后的表達(dá)式。有的符號有特殊意義,必須以 \ 將它的特殊意義去除,例如 \*,否則必須用單引號將它括起來,如 '*':
類別 |
語法 |
說明 |
條件判斷 |
expr1 \| expr2 |
如果 expr1 不是零或 null 則傳回 expr1,否則傳回 expr2。 |
expr1 \ expr2 |
如果 expr1 及 expr2 都不為零或 null,則傳回 expr1,否則傳回 0。 |
四則運算 |
expr1 + expr2 |
傳回 expr1 加 expr2 后的值。 |
expr1 - expr2 |
傳回 expr1 減 expr2 后的值。 |
expr1\* expr2 |
傳回 expr1 乘 expr2 后的值。 |
expr1 / expr2 |
傳回 expr1 除 expr2 后的值。 |
expr1 % expr2 |
傳回 expr1 除 expr2 的余數(shù)。 |
大小判斷 |
expr1 \&; expr2 |
如果 expr1 大于 expr2 則傳回 1,否則傳回 0。如果 expr1 及 expr2 都是數(shù)字,則是以數(shù)字大小判斷,否則是以文字判斷。以下皆同。 |
expr1 \ expr2 |
如果 expr1 小于 expr2 則傳回 1,否則傳回 0。 |
expr1 = expr2 |
如果 expr1 等于 expr2 則傳回 1,否則傳回 0。 |
expr1 != expr2 |
如果 expr1 不等于 expr2 則傳回 1,否則傳回 0。 |
expr1 \&;= expr2 |
如果 expr1 大于或等于 expr2 則傳回 1,否則傳回 0。 |
expr1 \= expr2 |
如果 expr1 小于或等于 expr2 則傳回 1,否則傳回 0。 |
文字處理 |
expr1 : expr2 |
比較一固定字符串,即 regular expression??梢允褂孟铝凶址麃磔o助:
. 匹配一個字符。
$ 找字符串的結(jié)尾。
[list] 找符合 list 中的任何字符串。
* 找尋 0 個或一個以上在 * 之前的字。
\( \) 傳回括號中所匹配的字符串。 |
我們針對比較復(fù)雜的文字處理部份再加以舉例:
復(fù)制代碼 代碼如下:
$ tty
ttyp0
$ expr `tty` : ".*\(..\)\$"
p0
$ expr `tty` : '.*\(..\)$'
p0
上面執(zhí)行 tty 的結(jié)果是 ttyp0,而在 expr 中,在 : 右側(cè)的表達(dá)式中,先找 .* 表示0個或一個以上任何字符,傳回之后在結(jié)尾 ($) 時的二個字符 \(..\)。在第一個 expr 的式子中,因為使用雙引號,所以在 $ 之前要用一個 \ 來去除 $ 的特殊意義,而第二個 expr 是使用單引號,在單引號內(nèi)的字都失去了特殊意義,所以在 $ 之前不必加 \。
除了使用 expr 外,我們還可以使用下列這種特殊語法:
復(fù)制代碼 代碼如下:
$ a=10
$ b=5
$ c=$((${a}+$))
$ echo $c
15
$ c=$((${a}*$))
$ echo $c
50
我們可以使用 $(()) 將表達(dá)式放在括號中,即可達(dá)到運算的功能。