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"))
>=      大于等于(需要双括号),如:(("$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" ]
        这个操作符将在[[]]结构中使用模式匹配.
<       小于,在ASCII字母顺序下.如:
        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)

相关推荐

  • shell实现四则运算简单方法

    1.简单方法 复制代码 代码如下: $ b=$((5*5+5-3/2)) $ echo $b29 在linux shell中,我们可以使用 $(()) 将表达式放在括号中,即可达到运算的功能. 2.其它方法: 用:expr 实现运算 复制代码 代码如下: $ expr 5 - 41 注意:将需要运算的表达式写入在expr 后面即可,保证 参数与运算符号中间有空格隔开. 类别 语法 说明 条件判断 expr1 \| expr2 如果 expr1 不是零或 null 则传回 expr1,否则传回 e

  • SHELL四则运算和比较

    1.操作符(let 标志符) +       加法-       减法*       乘法/       除法**      幂运算        3 let "z=5**3"%       取模        bash$ expr 5 % 3 2.比较符 (注意[ ]和变量之间需要空格" ") 整型比较符            -eq     等于,如:if [ "$a" -eq "$b" ]  //注意空格 -ne    

  • Linux Shell中的特殊符号和含义简明总结(包含了绝大部份)

    在Linux Shell中有很多的特殊符号,这对于我们写Shell脚本时要特别留意:一方面要知道这些特殊符号的用法,这些符号用好了可以达到事半功倍的效果:但另一方面要避免这些特殊符号的过度使用而导致脚本难以调试.难以阅读. 这些特殊符号罗列出来大致如下: 复制代码 代码如下: # ; ;; . , / / 'string'| ! $ ${} $? $$ $* "string"* ** ? : ^ $# $@ `command`{} [] [[]] () (()) || &~ ~

  • Shell动态生成数组的多种方法

    如果对linux shell 数组不是很熟悉的话,请看上一篇文章:linux shell 数组建立及使用技巧  ,这篇文章主要讲是动态生成数组系列.方法应该很多,我这里主要以一个求和计算的题目为例进行分析. 题目:请用linux shell 写一段脚本,实现从1..1000中所有偶数的和值. 方法一: 通过while 循环得到需要的结果: start=1; total=0; while [ $start -le 1000 ];do [[ $(($start%2)) == 0 ]]&&tot

  • shell脚本中一些特殊符号

    在shell中常用的特殊符号罗列如下: # ; ;; . , / \\ 'string'| ! $ ${} $? $$ $* \"string\"* ** ? : ^ $# $@ `command`{} [] [[]] () (()) || &~ ~+ ~- & \\<...\\> + - %= == != # 井号 (comments) 这几乎是个满场都有的符号,除了先前已经提过的\"第一行\" #!/bin/bash 井号也常出现在一

  • shell脚本实现本地文件与服务器文件同步

    为何创建此脚本是因为方便项目的布署,不需要手动地去同步不同的项目,而只需要简单的执行shell脚本,输入项目名就能发布到服器上. 1.shell文件代码 #!/bin/sh read -t 30 -p "请输入项目名:" name echo -e "\n" echo "项目名为:$name" case $name in cn) rsync -r ~/project1 root@192.168.18.2:/project1 --exclude=&q

  • shell脚本无密码登录 expect的使用方法详解

    shell脚本无密码登录 expect的使用方法详解 今天需要做一个定时任务脚本将最新的数据包文件传到远程的服务器上,虽然有密钥但也是要求输入密码的那种,所以只能另想办法实现让脚本自动输入密码了. 从网上查到使用expect可以,简单研究了一下,效果不错. 因为我的操作系统没有安装expect,所以直接"yum -y install expect",你可以根据你的操作系统安装expect,或者源码编译. 安装好之后就可以使用了,这里有几种方法: 一.单独写一个脚本 如 auto_scp

  • 两个很详细的shell 实例代码

    两个很详细的shell 实例 一般编程步骤 现在我们来讨论编写一个脚本的一般步骤.任何优秀的脚本都应该具有帮助和输入参数.并且写一个伪脚本(framework.sh),该脚本包含了大多数脚本都需要的框架结构,是一个非常不错的主意.这时候,在写一个新的脚本时我们只需要执行一下copy命令: cp framework.sh myscript 然后再插入自己的函数. 让我们再看两个例子: 二进制到十进制的转换 脚本 b2d 将二进制数 (比如 1101) 转换为相应的十进制数.这也是一个用expr命令

  • linux shell中 if else以及大于、小于、等于逻辑表达式介绍

    比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注意:这里的空格很重要.要确保方括号的空格.笔者就曾因为空格缺少或位置不对,而浪费好多宝贵的时间. if ....; then....elif ....; then....else....fi[ -f "somefile" ] :判断是否是一个文件[ -x "/bin/ls" ] :判断/bin/ls是否存在并有可执行权限[ -n "$var" ]

  • Wscript.Shell 对象详细介绍!!特好的东西第1/2页

    分类:程序WshShell 对象ProgID Wscript.Shell 文件名 WSHom.Ocx CLSID F935DC22-1CF0-11d0-ADB9-00C04FD58A0B IID F935DC21-1CF0-11d0-ADB9-00C04FD58A0B 下表说明和 WshShell 对象有关的属性. 属性 说明 Environment 返回 WshEnvironment 集合对象. SpecialFolders 使用 WshSpecialFolders 对象提供对 Windows

随机推荐