oracle shell 比对,SHELL四则运算和比较

1.操作符(let 标志符)

+       加法

-       减法

*       乘法

/       除法

**      幂运算

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"))

字符串比较

=       等于,如:if [ "$a" = "$b" ]

==      等于,如:if [ "$a" == "$b" ],与=等价

注意:==的功能在[[]]和[]中的行为是不同的,如下:

1 [[ $a == z* ]]    # 如果$a以"z"开头(模式匹配)那么将为true

2 [[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么结果为true

3

4 [ $a == z* ]      # File globbing 和word splitting将会发生

5 [ "$a" == "z*" ] # 如果$a等于z*(字符匹配),那么结果为true

一点解释,关于File globbing是一种关于文件的速记法,比如"*.c"就是,再如~也是.但是file globbing并不是严格的正则表达式,虽然绝大多数情况下结构比较像.

!=      不等于,如:if [ "$a" != "$b" ]

这个操作符将在[[]]结构中使用模式匹配.

if [[ "$a" < "$b" ]]

if [ "$a" \< "$b" ]

注意:在[]结构中"

>       大于,在ASCII字母顺序下.如:

if [[ "$a" > "$b" ]]

if [ "$a" \> "$b" ]

注意:在[]结构中">"需要被转义.

具体参考Example 26-11来查看这个操作符应用的例子.

-z      字符串为"null".就是长度为0.

-n      字符串不为"null"

注意:

使用-n在[]结构中测试必须要用""把变量引起来.使用一个未被""的字符串来使用! -z

或者就是未用""引用的字符串本身,放到[]结构中(见Example 7-6)虽然一般情况下可

以工作,但这是不安全的.习惯于使用""来测试字符串是一种好习惯.

3.eg

#./bin/bash

#获取英文月份对应的数字月份

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

}

# 判断是否有过期短信,有调用C删除短信函数

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中调用C函数的结果

else

echo "消息队列中没有过期的短信"

fi

}

#获取当前月份对应的天数

cd /mas/shell/zhangweiatest/clear_overtime_sms

mday=`./getmonthofday`

echo "当前月份前一个月对应的天数=$mday"

#获取系统时间对应的年,月

buff=`date|awk '{print $2,$3}'`

now_month=${buff:0:1}

now_day=${buff:3:1}

#获取当前队列的存活时间

ipcs -qt|awk '{print $1,$3,$4}'>msglivelytime.ini

sed -n '4,$p' msglivelytime.ini >msglivelytime1.ini //获取从第四行开始到结束的字符

mv msglivelytime1.ini msglivelytime.ini

while read msgid msg_month msg_day

do

echo

echo "消息队列ID=$msgid创建的时间为:$msg_month月$msg_day日"

echo "系统时间为$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 这个指令来辅助。因为这是一个指令,所以如果要将结果指定给变量,必须使用 ` 包起来。请注意,在 + - * / 的二边都有空白,如果没有空白将产生错误:

$ expr 5 -2

3

$ sum=`expr 5 + 10`

$ echo $sum

15

$ sum=`expr $sum / 3`

$ echo $sum

5

还有一个要特别注意的是乘号 * 在用 expr 运算时,不可只写 *。因为 * 有其它意义,所以要使用 \* 来代表。另外,也可以用 % 来求余数。

$ count=`expr 5 \* 3`

$ echo $count

$ echo `expr $count % 3`

5

我们再列出更多使用 expr 指令的方式,下列表中为可以放在指令 expr 之后的表达式。有的符号有特殊意义,必须以 \ 将它的特殊意义去除,例如 \*,否则必须用单引号将它括起来,如 '*':

类别

语法

说明

条件判断

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 的余数。

大小判断

expr1 \> expr2

如果 expr1 大于 expr2 则传回 1,否则传回 0。如果 expr1 及 expr2 都是数字,则是以数字大小判断,否则是以文字判断。以下皆同。

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。可以使用下列字符来辅助:

. 匹配一个字符。

$ 找字符串的结尾。

[list] 找符合 list 中的任何字符串。

* 找寻 0 个或一个以上在 * 之前的字。

\( \) 传回括号中所匹配的字符串。

我们针对比较复杂的文字处理部份再加以举例:

$ tty

ttyp0

$ expr `tty` : ".*\(..\)\$"

p0

$ expr `tty` : '.*\(..\)$'

p0

上面执行 tty 的结果是 ttyp0,而在 expr 中,在 : 右侧的表达式中,先找 .* 表示0个或一个以上任何字符,传回之后在结尾 ($) 时的二个字符 \(..\)。在第一个 expr 的式子中,因为使用双引号,所以在 $ 之前要用一个 \ 来去除 $ 的特殊意义,而第二个 expr 是使用单引号,在单引号内的字都失去了特殊意义,所以在 $ 之前不必加 \。

除了使用 expr 外,我们还可以使用下列这种特殊语法:

$ a=10

$ b=5

$ c=$((${a}+${b}))

$ echo $c

15

$ c=$((${a}*${b}))

$ echo $c

50

我们可以使用 $(()) 将表达式放在括号中,即可达到运算的功能。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值