免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4449 | 回复: 10
打印 上一主题 下一主题

[数值计算] awk 数值求和 [复制链接]

论坛徽章:
1
15-16赛季CBA联赛之山东
日期:2016-03-02 14:33:02
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-03-03 16:05 |只看该作者 |倒序浏览
一 计算每行数值的和
输入数据
jack 70 80 90
tom 60 70 80
jenny 50 70 60
输出数据
jack        240
jenny        180
tom        210
二 计算所有数字 的和
输入数据
1 2 3 4 5
6 7 8 9 10
输出数据
55

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
2 [报告]
发表于 2016-03-03 16:08 |只看该作者
如果是   jack 70  mike 80   petter  90   呢,应该输出什么格式?

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
3 [报告]
发表于 2016-03-03 16:09 |只看该作者
  1. awk '{for(i=3;i<=NF;i++)$2+=$i;NF=2}1'

  2. awk -vRS='' '{for(i=2;i<=NF;i++)$1+=$i;NF=1}1'
复制代码

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
4 [报告]
发表于 2016-03-03 16:20 |只看该作者
本帖最后由 jason680 于 2016-03-03 16:29 编辑

回复 1# 寂寞卜孤单

$ cat F1
jack 70 80 90
tom 60 70 80
jenny 50 70 60

$ awk '{print $1,$2+$3+$4}' F1
jack 240
tom 210
jenny 180


$ cat F2
1 2 3 4 5
6 7 8 9 10

$ awk '{for(n=1;n<=NF;++n)s+=$n}END{print s}' F2
55

$ awk -vRS=" |\n" '{s+=$1}END{print s}' F2
55


   

论坛徽章:
1
15-16赛季CBA联赛之山东
日期:2016-03-02 14:33:02
5 [报告]
发表于 2016-03-03 16:25 |只看该作者
回复 3# haooooaaa


   awk -vRS='' '{for(i=2;i<=NF;i++)$1+=$i;NF=1}1'
这个,第一个数字没有被算进去啊

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
6 [报告]
发表于 2016-03-03 16:26 |只看该作者
回复 5# 寂寞卜孤单
  1. cyg@win /tmp$ more f
  2. 1 2 3 4 5
  3. 6 7 8 9 10

  4. cyg@win /tmp$ awk -vRS='' '{for(i=2;i<=NF;i++)$1+=$i;NF=1}1' f
  5. 55
复制代码

论坛徽章:
28
2015年迎新春徽章
日期:2015-03-04 10:16:53午马
日期:2015-03-20 17:11:07亥猪
日期:2015-03-20 17:11:23戌狗
日期:2015-03-20 17:11:33酉鸡
日期:2015-03-20 17:11:47申猴
日期:2015-03-20 17:11:58未羊
日期:2015-03-20 17:12:10子鼠
日期:2015-03-20 17:12:23丑牛
日期:2015-03-20 17:12:40卯兔
日期:2015-03-20 17:12:51辰龙
日期:2015-03-20 17:13:00巳蛇
日期:2015-03-20 17:13:12
7 [报告]
发表于 2016-03-03 16:38 |只看该作者
  1. awk '($2+=$3+$4)&&NF=2'
  2. awk -vRS='[ \n]' '{b=$0;while(getline a)b+=a}$0=b'
复制代码

论坛徽章:
6
羊年新春福章
日期:2015-03-03 17:16:28双子座
日期:2015-03-03 17:16:56巳蛇
日期:2015-03-03 17:17:2415-16赛季CBA联赛之福建
日期:2016-03-11 09:05:00黑曼巴
日期:2016-07-07 16:58:1215-16赛季CBA联赛之吉林
日期:2016-11-14 09:23:07
8 [报告]
发表于 2016-03-04 09:52 |只看该作者
1.awk '{sum=$2+$3+$4;print $1,sum}' file

2.awk '{for(i=1;i<=NF;i++)sum+=$i}END{print sum}' file

论坛徽章:
2
luobin
日期:2016-06-17 17:46:36lufei
日期:2016-06-17 17:49:16
9 [报告]
发表于 2016-03-04 13:19 |只看该作者
awk 's=0;{for(i=1;i<=NF;i++)s=$s+i;{print $1 "\t" s}}' filename

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
10 [报告]
发表于 2016-03-06 09:35 |只看该作者
  1. awk '{sum = 0;for(i=1;++i<=NF;){sum += $i;}print $1,sum}' urfile|sort -k1

  2. awk -vRS='' '{for(i=0;i++<NF;){sum+=$i;}print sum}' urfile  
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP