免费注册 查看新帖 |

Chinaunix

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

这个shell 大家会写吗? 用awk写! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-17 17:40 |只看该作者 |倒序浏览
1 2 3 4 5 6
1 2 3 4 5 6
1 2 3 4 5 6


用awk写的结果是:

1 2  3  4  5   6    11
1 2  3  4  5   6    11
1 2  3  4  5   6    11
3 8  9 12 15 18  33

第7个域的结果是前6个域的和,
最后一行的结果是前三行各个域的和!

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2008-06-17 18:05 |只看该作者

  1. while read a b c d e f;do ((sa+=a));((sb+=b));((sc+=c));((sd+=d));((se+=e));((sf+=f));((sg+=$((a+b+c+d+e+f))));echo $a $b $c $d $e $f $((a+b+c+d+e+f));done<ur-file;echo $sa $sb $sc $sd $se $sf $sg
复制代码


awk,;

  1. awk '{a+=$1;b+=$2;c+=$3;d+=$4;e+=$5;f+=$6;g=(a+b+c+d+e+f);print $0,$1+$2+$3+$4+$5+$6}END{print a,b,c,d,e,f,g}'
复制代码

[ 本帖最后由 寂寞烈火 于 2008-6-17 18:16 编辑 ]

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
3 [报告]
发表于 2008-06-17 18:26 |只看该作者

  1. awk '{t=0;for(i=1;i<=6;i++){t+=$i;a[i]+=$i}printf("%s\t%d\n",$0,t)}END{for(i=1;i<=6;i++)printf("%d ",a[i]);printf("\n")}'
复制代码

[ 本帖最后由 cjaizss 于 2008-6-17 18:44 编辑 ]

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
4 [报告]
发表于 2008-06-17 19:35 |只看该作者
原帖由 cjaizss 于 2008-6-17 18:26 发表

awk '{t=0;for(i=1;i


缺个功能,最后的一列也要累加:

  1. awk '{t=0;for(i=1;i<=6;i++){t+=$i;a[i]+=$i;printf "%2s " ,$i}print t;a[7]+=t}END{for(i=1;i<=6;i++) printf "%2s " ,a[i];print a[7]}' urfile
复制代码

论坛徽章:
0
5 [报告]
发表于 2008-06-18 09:28 |只看该作者

回复 #2 寂寞烈火 的帖子

不错,谢了!

论坛徽章:
0
6 [报告]
发表于 2008-06-18 15:26 |只看该作者
awk 'BEGIN{sum=0}{for(i=1;i<=NF;i++){a[NR]+=$i;b+=$i;};printf("%s %s\n",$0,a[NR]);sum+=a[NR];}END{for(i in b){printf("%s ",b)};print sum}' ./datafile

论坛徽章:
0
7 [报告]
发表于 2008-06-18 15:41 |只看该作者

回复 #6 justlooks 的帖子

for i in b?
b是数组麽?

论坛徽章:
0
8 [报告]
发表于 2008-06-18 15:43 |只看该作者
原帖由 kingsu 于 2008-6-18 15:41 发表
for i in b?
b是数组麽?


for i in b 这句就是遍历b数组

论坛徽章:
0
9 [报告]
发表于 2008-06-18 15:47 |只看该作者

回复 #8 justlooks 的帖子

我是不明白b什么时候变成数组了。。。

我对数组绝望了。。。

论坛徽章:
0
10 [报告]
发表于 2008-06-18 16:15 |只看该作者
awk 'BEGIN{sum=0}{for(i=1;i<=NF;i++){a[NR]+=$i;b+=$i;};printf("%s %s\n",$0,a[NR]);sum+=a[NR];}END{for(i in b){printf("%s ",b)};print sum}' ./datafile


应该是这样,不好意思.........
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP