免费注册 查看新帖 |

Chinaunix

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

关于shell合并行的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-03-24 22:00 |只看该作者 |倒序浏览
18:00  2  3  4  5  6  7
18:00  2  3  4  5  6  7
18:00  2  3  4  5  6  7
19:00  2  3  4  5  6  7
19:00  2  3  4  5  6  7
19:00  2  3  4  5  6  7
20:00  2  3  4  5  6  7
20:00  2  3  4  5  6  7
20:00  2  3  4  5  6  7

怎么把同一小时的 后面所有行相加合并呢?

awk '{s[$1]+=$2}END{for (a in s) print a,s[a] }'
这样写只能合并 第二项
或者
awk '{s[$1]+=$2;j[$1]+=$3}END{for (a in s) print a, s[a],j[a] }' 一直写很多
有没有更好的方法呢?

论坛徽章:
0
2 [报告]
发表于 2009-03-24 22:44 |只看该作者

回复 #1 星期二 的帖子

[test]$ cat 4
18.00  2  3  4  5  6  7
18.00  2  3  4  5  6  7
18.00  2  3  4  5  6  7
19.00  2  3  4  5  6  7
19.00  2  3  4  5  6  7
19.00  2  3  4  5  6  7
20.00  2  3  4  5  6  7
20.00  2  3  4  5  6  7
20.00  2  3  4  5  6  7
[test]$ awk '{for(i=2;i<=NF;i++)a[$1]+=$i}END{for(i in a)print i,a}' 4
20.00 81
18.00 81
19.00 81

论坛徽章:
0
3 [报告]
发表于 2009-03-24 23:11 |只看该作者
不是这个意思
是要这样的结果
18.00  6  9  12  15  18  21
19.00  6  9  12  15  18  21
20.00  6  9  12  15  18  21

论坛徽章:
0
4 [报告]
发表于 2009-03-25 07:09 |只看该作者
如果文件中的第一列是连续的,可以试试:
awk -v lastline=$(wc -l file|awk '{print $1}')  '{if(NR==1||$1==count[1]){count[1]=$1;for(j=2;j<=NF;j++) count[j]+=$j;}isequal=$1==count[1];if($1!=count[1]||NR==lastline){printf count[1]" ";count[1]=$1;for(j=2;j<=NF;j++){printf count[j]" ";count[j]=$j;}print "";}if(NR==lastline&&!isequal)print $0;}' file
看起来写的很复杂,期待更简单的写法!

[ 本帖最后由 dream3401 于 2009-3-25 07:33 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2009-03-25 07:46 |只看该作者
我故意打乱了数据行顺序,如果最后结果要排序再加个管道sort
  1. [root@Mylinux tmp]# cat file
  2. 18:00  2  3  4  5  6  7
  3. 19:00  2  3  4  5  6  7
  4. 19:00  2  3  4  5  6  7
  5. 18:00  2  3  4  5  6  7
  6. 18:00  2  3  4  5  6  7
  7. 19:00  2  3  4  5  6  7
  8. 20:00  2  3  4  5  6  7
  9. 20:00  2  3  4  5  6  7
  10. 20:00  2  3  4  5  6  7
  11. [root@Mylinux tmp]# awk '{split(a[$1],M," ");for (i=1;i<=6;i++) M[i]=M[i]+$(i+1);a[$1]=M[1]" "M[2]" "M[3]" "M[4]" "M[5]" "M[6]}END{for (j in a) print j" "a[j]}' file
  12. 19:00 6 9 12 15 18 21
  13. 18:00 6 9 12 15 18 21
  14. 20:00 6 9 12 15 18 21
复制代码

[ 本帖最后由 ywlscpl 于 2009-3-25 07:53 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2009-03-25 08:57 |只看该作者
原帖由 ywlscpl 于 2009-3-25 07:46 发表
我故意打乱了数据行顺序,如果最后结果要排序再加个管道sort
[root@Mylinux tmp]# cat file
18:00  2  3  4  5  6  7
19:00  2  3  4  5  6  7
19:00  2  3  4  5  6  7
18:00  2  3  4  5  6  7
18: ...


佩服,进步神速啊!!!

论坛徽章:
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
7 [报告]
发表于 2009-03-25 09:14 |只看该作者

回复 #1 星期二 的帖子

可以模拟个二维数组来做:

  1. awk '{b[$1]++;for(i=2;i<=NF;i++) a[$1"-"i]+=$i}END{for(i in b){printf i;for(j=2;j<=NF;j++)printf " "a[i"-"j];print ""}}' urfile
复制代码

论坛徽章:
0
8 [报告]
发表于 2009-03-25 09:23 |只看该作者
原帖由 ly5066113 于 2009-3-25 09:14 发表
可以模拟个二维数组来做:

awk '{b[$1]++;for(i=2;i


第一次看到awk的二维数组,学习下先,谢谢!

论坛徽章:
0
9 [报告]
发表于 2009-03-25 09:41 |只看该作者
原帖由 ly5066113 于 2009-3-25 09:14 发表
可以模拟个二维数组来做:

awk '{b[$1]++;for(i=2;i



学习下

论坛徽章:
0
10 [报告]
发表于 2009-03-25 09:42 |只看该作者
tim的二维数组长见识
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP