Linux下的计算命令和求和、求平均值、求最值命令梳理

在Linux系统下,经常会有一些计算需求,那么下面就简单梳理下几个常用到的计算命令

(1)bc命令 bc命令是一种支持任意精度的交互执行的计算器语言。bash内置了对整数四则运算的支持,但是并不支持浮点运算,而bc命令可以很方便的进行浮点运算,当然整数运算也不再话下 常用参数选项: -i:强制进入交互式模式; -l:定义使用的标准数学库; -w:对POSIX bc的扩展给出警告信息; -q:不打印正常的GNU bc环境信息; -v:显示指令版本信息; -h:显示指令的帮助信息。

在bc工作环境下,可以使用以下计算符号: +    加法 -     减法 *    乘法 /     除法 ^    指数 %   余数 其中,在做“除法计算”或“余数计算”时,可以使用scale指定小数点之后的位数(默认为0,即整数)

实例说明:

[root@slave-server ~]# bc -v
bc 1.06.95
Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006 Free Software Foundation, Inc.
[root@slave-server ~]# bc <<< 5*4  
20
[root@slave-server ~]# bc <<< 5+4  
9
[root@slave-server ~]# bc <<< 50-14  
36
[root@slave-server ~]# bc <<< 50/10
5
[root@slave-server ~]# bc <<< 50/3
16
[root@slave-server ~]# bc <<< 3^3
27

如下,进入交互模式: 也可以一行输入多个计算,用逗号;相隔。

[root@slave-server ~]# bc
bc 1.06.95
Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006 Free Software Foundation, Inc.
This is free software with ABSOLUTELY NO WARRANTY.
For details type `warranty'. 
3+10
13
10-5
5
10*10
100
10^2
100
10/2
5
10/3
3
scale=4
10/3
3.3333
10%3
.0001
3+4;5*2;5^2;18/4 
7
10
25
4.5000
10^3;100+50;4000-598;33*8;899/34
1000
150
3402
264
26.4411

以上是使用交互的计算,也可以不进行交互而直接计算出结果。 1)结合echo和|符合 [root@slave-server ~]# echo "(6+3)*2" |bc 18 [root@slave-server ~]# echo 15/4 |bc 3 [root@slave-server ~]# echo "scale=2;15/4" |bc 3.75 [root@slave-server ~]# echo "scale=2;100/30*100-98;20+45;90-70;15^2" |bc 235.00 65 20 225 [root@slave-server ~]# echo "3+4;5*2;5^2;18/4" |bc 7 10 25 4 2)bc除了scale来设定小数位之外,还有ibase和obase来其它进制的运算。 如下实例: 将16进制的A7输出为10进制, 注意,英文只能大写 [root@slave-server ~]# echo "ibase=16;A7" |bc 167 将2进制的11111111转成10进制 [root@slave-server ~]# echo "ibase=2;11111111" |bc 255 输入为16进制,输出为2进制 [root@slave-server ~]# echo "ibase=16;obase=2;B5-A4" |bc 10001

3)除此之外bc后可以接文件名(指定包含计算任务的文件)

[root@slave-server ~]# cat calc.txt
20+89
56-17
34*45
30/8
2^5
scale=5
100/3
200%17
[root@slave-server ~]# bc calc.txt
bc 1.06.95
Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006 Free Software Foundation, Inc.
This is free software with ABSOLUTELY NO WARRANTY.
For details type `warranty'. 
109
39
1530
3
32
33.33333
.00010

不打印正常的GNU信息
[root@slave-server ~]# bc -q calc.txt
109
39
1530
3
32
33.33333
.00010

[root@slave-server ~]# bc -q < calc.txt
109
39
1530
3
32
33.33333
.00010
[root@slave-server ~]#

4)也可以使用HERE 命令:

[root@slave-server ~]# bc << HERE 
> 30+56
> 30-14
> 30*5
> scale=3
> 30/7
> 10%3
> 2^7
HERE
86
16
150
4.285
.001
128

5)可以使用内置的变量last引用上一次的结果:

[root@slave-server ~]# echo "50*4;last+100" | bc  
200
300

last也可以用点号代替:

[root@slave-server ~]# echo "50*4;.+100" | bc  
200
300

6)脚本模拟计算器

[root@slave-server ~]# cat bc.sh 
#!/bin/bash 
bc << EOF  
scale=2  
$@  
EOF
[root@slave-server ~]# chmod 755 bc.sh
[root@slave-server ~]# ./bc.sh 10*2
20
[root@slave-server ~]# ./bc.sh 10+32
42
[root@slave-server ~]# /bin/bash bc.sh 100/3
33.33
[root@slave-server ~]# /bin/bash -x bc.sh 100%13
+ bc
.03

(2)expr命令 expr命令不光能计算加减乘除,还有很多表达式都可以计算出结果。 不过有一点需要注意,在计算加减乘除时,不要忘了使用空格和转义。 实例说明:

[root@slave-server ~]#  expr 6 + 3                //注意中间都有空格
9
[root@slave-server ~]# expr 2 \* 3                //注意乘法符号*前面有转义符号
6
[root@slave-server ~]# expr 14 % 9 
5
[root@slave-server ~]# a=3
[root@slave-server ~]# expr $a + 5     //注意有变量,有空格
8
[root@slave-server ~]# a=`expr 4 + 2`
[root@slave-server ~]# echo $a
6

expr对于字串的操作(计算)也很方便:

[root@slave-server ~]# expr length "yangzhigang.cublog.cn" 
21

从位置处抓取字串

[root@slave-server ~]# expr substr "yangzhigang.cublog.cn" 1 11
yangzhigang

字串开始处

[root@slave-server ~]# expr index "yangzhigang.cublog.cn" cu
13

(3)echo命令 echo用来进行回显,是周知的事。上面也配合bc来进行计算。其实echo也可以单独进行简单的计算

[root@slave-server ~]# echo $((3+5))
8
[root@slave-server ~]# echo $(((3+5)*2))
16

echo还可以进行变量的计算

[root@slave-server ~]# a=10
[root@slave-server ~]# b=5
[root@slave-server ~]# echo $(($a+$b))
15
[root@slave-server ~]# echo $a+$b
10+5
[root@slave-server ~]# echo $a+$b |bc
15

计算前天的日期

[root@slave-server ~]# echo `date +%Y%m%d`
20170204
[root@slave-server ~]# echo `date +%Y%m%d`-2
20170204-2
[root@slave-server ~]# echo `date +%Y%m%d`-2 |bc
20170202

(4)AWK命令 awk在处理文件的时,可以进行运算,那当然也可以单单用来计算了

[root@slave-server ~]# awk 'BEGIN{a=3+2;print a}'
5
[root@slave-server ~]# awk 'BEGIN{a=(3+2)*2;print a}'
10
[root@slave-server ~]# awk 'BEGIN{a=(3+2)*2;b=(5+8)*10/5;print a,b}'
10 26
[root@slave-server ~]# awk 'BEGIN{a=(3+2)*2;b=(5+8)*10/5;print 2a,3b}'
210 326
[root@slave-server ~]# awk 'BEGIN{a=(3+2)*2;b=(5+8)*10/5;c=5^2;print a,b,3c}'
10 26 325

-------------------------------------------------

求和、平均值、最值 [root@redis-server1 ~]# cat a 1 2 3 4 5 2333 [root

(0)求和 [root@redis-server1 ~]# awk '{a+=$1}END{print a}' a 2348

(1)求最大值 [root@redis-server1 ~]# awk '$0>a{a=$0}END{print a}' a 2333

(2)求最小值(思路:先定义一个最大值) [root@redis-server1 ~]# awk 'BEGIN{a=9999999}{if($1<a) a=$1 fi}END{print a}' a 1

(3)求平均值 第一种方法:在上面求和的基础上,除以参数个数 [root@redis-server1 ~]# awk '{a+=$1}END{print a/NR}' a 391.333

第二种方法:写脚本 [root@redis-server1 ~]# cat avg.sh

#!/bin/bash
let sum=0
for num in $*;do
let sum=$sum+$num
done
echo "scale=3;$sum/$#"|bc

[root@redis-server1 ~]# chmod 755 avg.sh [root@redis-server1 ~]# ./avg.sh `cat a` 391.333

[root@redis-server1 ~]# ./avg.sh 40 45 60 48.333 ..................... $? 上一个命令结果的返回值,0是正确,非0是错误的 $0 当前程序名 $n 命令行参数,比如$1是第一个参数,$2是第二个参数,$3是第三个参数..... $# 命令行参数的个数 $* 格式形如$1 $2 $3 $4 ... $n $@ 格式形如"$1" "$2" "$3" "$4" ... "$n"

---------------------------------再看一例----------------------------------- [root@redis-server1 ~]# cat a.txt A 88 B 78 B 89 C 44 A 98 C 433

取得结果为:[root@redis-server1 ~]# cat a.txt|awk -F" " '{print $1}'|sort|uniq A B C

第一种方法: [root@redis-server1 ~]# cat a.txt|awk -F" " '{print $1}'|sort|uniq A B C [root@redis-server1 ~]# for i in `cat a.txt|awk -F" " '{print $1}'|sort|uniq`;do cat a.txt|grep $i|xargs;done A 88 A 98 B 78 B 89 C 44 C 433 [root@redis-server1 ~]# for i in `cat a.txt|awk -F" " '{print $1}'|sort|uniq`;do cat a.txt|grep $i|xargs;done|awk '{print $1,$2,$4}' A 88 98 B 78 89 C 44 433

[root@redis-server1 ~]# for i in `cat a.txt|awk -F" " '{print $1}'|sort|uniq`;do cat a.txt|grep $i|xargs;done|awk -F" " '{print $1":",$2":",$4}' A: 88: 98 B: 78: 89 C: 44: 433

第二种方法: [root@redis-server1 ~]# awk '{a[$1]=a[$1]" "$2}END{for(i in a)print i,a[i]}' a.txt |awk '{print $1":",$2";",$3}' A: 88; 98 B: 78; 89 C: 44; 433

------------------------------------------------------------------------ 其它实例: [root@redis-server1 ~]# cat b.txt 123 444 23 888 455 45 55 367 66 100 77 89

对上面b.txt文件里的两列数字分别求和,求平均值 [root@redis-server1 ~]# awk '{a+=$1;b+=$2}END{print a,b}' b.txt 799 1933 [root@redis-server1 ~]# awk '{a+=$1;b+=$2}END{print a":",b}' b.txt 799: 1933 [root@redis-server1 ~]# awk '{a+=$1;b+=$2}END{print a":"b}' b.txt 799:1933

[root@redis-server1 ~]# awk '{a+=$1;b+=$2}END{print a/NR,b/NR}' b.txt 133.167 322.167 [root@redis-server1 ~]# awk '{a+=$1;b+=$2}END{print a/NR":",b/NR}' b.txt 133.167: 322.167 [root@redis-server1 ~]# awk '{a+=$1;b+=$2}END{print a/NR":"b/NR}' b.txt 133.167:322.167

-------------------------------------------------------------- paste 命令将多个文件合并 [root@redis-server1 ~]# cat aa.txt 11 22 33 44 55 [root@redis-server1 ~]# cat bb.txt aa ab ac cc cd

[root@redis-server1 ~]# paste aa.txt bb.txt 11 aa 22 ab 33 ac 44 cc 55 cd [root@redis-server1 ~]# paste -d":" aa.txt bb.txt 11:aa 22:ab 33:ac 44:cc 55:cd [root@redis-server1 ~]# paste -d"-" aa.txt bb.txt 11-aa 22-ab 33-ac 44-cc 55-cd

---------------再看几个条件判断的例子------------------

[root@master-node ~]# cat aa.txt
123 root 
345 wangshibo
456 opt
789 nginx
100 wangshibo
200 huanqiu
300 hqtime

打印aa.txt文件中第二列包含wang字符的内容
[root@master-node ~]# awk '$2~/wang/ {print $0}' aa.txt
345 wangshibo
100 wangshibo

打印aa.txt文件中第二列不包含wang字符的内容
[root@master-node ~]# awk '$2 !~/wang/ {print $0}' aa.txt
123 root 
456 opt
789 nginx
200 huanqiu
300 hqtime

打印aa.txt文件中第二列以wang字符开头的内容
[root@master-node ~]# awk '$2~/^wang/ {print $0}' aa.txt
345 wangshibo
100 wangshibo

打印aa.txt文件中第二列以bo字符结尾的内容
[root@master-node ~]# awk '$2~/bo$/ {print $0}' aa.txt
345 wangshibo
100 wangshibo

打印aa.txt文件中第二列是wangshibo的内容(精确匹配)
[root@master-node ~]# awk '$2=="wangshibo" {print $0}' aa.txt
345 wangshibo
100 wangshibo

打印aa.txt文件中第二列不是wangshibo的内容
[root@master-node ~]# awk '$2!="wangshibo" {print $0}' aa.txt
123 root 
456 opt
789 nginx
200 huanqiu
300 hqtime

打印aa.txt文件中第一列数字大于500的内容
[root@master-node ~]# awk '$1>500 {print $0}' aa.txt
789 nginx

打印aa.txt文件中第一列数字大于500且第二列是wangshibo的内容
[root@master-node ~]# awk '$1<200 && $2=="wangshibo" {print $0}' aa.txt
100 wangshibo

打印aa.txt文件中第一列数字大于500或是第二列是wangshibo的内容
[root@master-node ~]# awk '$1<200 || $2=="wangshibo" {print $0}' aa.txt
123 root 
345 wangshibo
100 wangshibo

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏架构说

缓存策略之LRU实现及分析

LRU定义 Cache的容量有限,因此当Cache的容量用完后,而又有新的内容需要添加进来时, 就需要挑选并舍弃原有的部分内容,从而腾出空间...

33910
来自专栏python3

python3--模块collections,time,random,sys

有如下值集合[11,22,33,44,55,66,77,88,99,90......],将所有大于66的值保存至字典的第一个key中,小于66的值保存至第二个k...

1002
来自专栏Spark学习技巧

ConcurrentHashMap实现原理

1474
来自专栏软件开发 -- 分享 互助 成长

模板方法模式

一、简介 1、模板方法模式定义一个操作中的算法骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。 2、说白...

1947
来自专栏遊俠扎彪

Linux内核代码中max和min宏的实现以及语句表达是({})的应用

Linux内核代码中有很多比较精巧的程序设计技巧,include/linux/kernel.h中实现max和min宏就是其中的一部分。

2285
来自专栏机器学习从入门到成神

队列和栈面试题(一)— 请编写一个程序,按升序对栈进行排序,要求最多只能使用一个额外的栈存放临时数据

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_35512245/articl...

1232
来自专栏机器学习实践二三事

Redis数据结构

主要内容来源于书籍Redis实战(Redis In Action),这篇只是用来记录自己学习的过程,因为刚学所以很浅显,适合初学者哈 Redis数据结构 5种数...

2139
来自专栏java一日一条

细说 MySQL 之 MEM_ROOT

这篇文章会详细解说MySQL中使用非常广泛的MEM_ROOT的结构体,同时省去debug部分的信息,仅分析正常情况下,mysql中使用MEM_ROOT来做内存分...

811
来自专栏海天一树

小朋友学C语言(42):gets和fgets

这里可以看出来,定义了s的长度为3,但是用gets()输入字符串的时候,并不会去检查字符串的长度,所以导致char的值不是a,而是”uvwxyz”中的第四个字符...

1571
来自专栏开源优测

[快学Python3]XML解析处理 - Element Tree

概述 本文就是python xml解析进行讲解,在python中解析xml有很多种方法,本文通过实例来讲解如何使用ElementTree来解析xml。对于其他的...

4278

扫码关注云+社区

领取腾讯云代金券