Linux Shell 算术运算

米扑博客 总结了 Bash shell 的算术运算有四种方式:

1、使用 expr 外部程式

加法 r=`expr 4 + 5` echo $r

注意! '4' '+' '5' 这三者之间要有空格

r=`expr 4 * 5` # 错误 乘法 r=`expr 4 \* 5`

2、使用 $(( ))

r=$(( 4 + 5 )) echo $r

3、使用 $[ ]

r=$[ 4 + 5 ] echo $r

乘法 r=`expr 4 \* 5`  r=$(( 4 * 5 )) r=$[ 4 * 5 ] echo $r

除法 r=`expr 40 / 5`  r=$(( 40 / 5 )) r=$[ 40 / 5 ] echo $r

减法 r=`expr 40 - 5`  r=$(( 40 - 5 )) r=$[ 40 - 5 ] echo $r

求余数 r=$[ 100 % 43 ] echo $r

乘幂 (如 2 的 3 次方) r=$(( 2 ** 3 )) r=$[ 2 ** 3 ] echo $r 注:expr 沒有乘幂

4、使用let 命令

加法: n=10 let n=n+1 echo $n #n=11

乘法: let m=n*10 echo $m

除法: let r=m/10 echo $r

求余数: let r=m%7 echo $r

乘冪: let r=m**2 echo $r

虽然Bash shell 有四种算术运算方法,但并不是每一种都是跨平台的,建议使用expr。 另外,我们在 script 中经常有加1操作,以下四法皆可: m=$[ m + 1] m=`expr $m + 1` m=$(($m + 1)) let m=m+1

Shell awk 循环求和

1. 简单求和

12345678

$ cat test.txt 1122334455$ awk '{sum += $1};END{print sum}' test.txt  165

2. 特定列求和

12345678

$ cat test.txt aa      11bb      22cc      33aa      44dd      55$ awk '/aa/ {sum += $2};END {print sum}' test.txt 55

3. 求和、平均数、最大值、最小值

1234567891011121314

$ cat test.txt aa      11bb      22cc      33aa      44dd      55$ cat test.txt | awk '{sum += $2};END {print sum}'165$ cat test.txt | awk '{sum += $2};END {print sum/NR}'33$ cat test.txt | awk 'BEGIN {max=0} {if($2>max) max=$2 fi};END {print max}'55$ cat test.txt | awk 'BEGIN {min=999999999} {if($2<min) min=$2 fi};END {print min}'        11

awk 浮点运算:

运算表达式: awk 'BEGIN{printf "%.6f\n", ( 10 / 3)}'

运算结果: 3.333333

PS:shell的内部算术运算符无法处理浮点数,所以当需要处理浮点数是,要用到外部工具(如awk)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java学习123

mysql分组查询

35490
来自专栏JavaEE

mybatis的association以及collection的用法association:一对一关联(has one)collection:一对多关联(has many)

74280
来自专栏Java呓语

第9章、语言结构

字符串是包含在单引号(')或双引号(")字符中的字节或字符序列。 以下几行例子是等同的:

10230
来自专栏跟着阿笨一起玩NET

sql server 获取每一个类别中值最大的一条数据

SELECT  * FROM    (           SELECT    * ,                     ROW_NUMBER() OVE...

48010
来自专栏栗霖积跬步之旅

第12章:汇总数据

表名:products  字段:product_id、product_name、product_price、vend_id(供应商) 12.1聚集函数: 我们常...

20400
来自专栏乐沙弥的世界

PL/SQL 集合的方法

    PL/SQL中提供了常用的三种集合联合数组、嵌套表、变长数组,而对于这几个集合类型中元素的操作,PL/SQL提供了相应的函数或过程来操 纵数组中的元素...

9030
来自专栏Python

表的数据类型

一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的 详细参考: http://www.runoob....

22470
来自专栏技术专栏

hive 中 统计某字段json数组中每个value出现的次数

需要将json数组里的qd_title都提取出来转换成hive中的array数组。下面介绍两种方法

1.4K30
来自专栏desperate633

第14课 组合查询创建组合查询union的使用规则

组合查询很容易理解就是讲多个查询的结果放在一起显示 使用UNION关键字进行查询的组合

9220
来自专栏JavaEE

mybatis笔记整理mybatis的基本用法及配置:

441110

扫码关注云+社区

领取腾讯云代金券