免费注册 查看新帖 |

Chinaunix

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

awk问题,求解(已解) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-02-14 18:20 |只看该作者 |倒序浏览
本帖最后由 asplinux 于 2012-02-15 12:21 编辑

这几天一直在看 unix shell 范例精解 ,被一道awk习题卡住了
文件如下
lab5.data部分内容:
  1. Mike Harrington:(510) 548-1278:250:100:175
  2. Christian Dobbins:(408) 538-2358:155:90:201
  3. Susan Dalsass:(206) 654-6279:250:60:50
  4. Archie McNichol:(206) 548-1348:250:100:175
  5. Jody Savage:(206) 548-1278:15:188:150
  6. Guy Quigley:(916) 343-6410:250:100:175
复制代码
要求写个能输出如下形式的脚本
  1. Mike Harrington       (510) 548-1278251017   250  100 175
  2. Christian Dobbins     (408) 538-2358159020   155  90  201
  3. total:971
  4. avg:485.5
复制代码
我的做法将

  1. #!/bin/awk
  2. BEGIN{
  3. -F":"
  4. printf "----------------------------------------------------------------\n"
  5. printf "%-20s%-16s  Jan  |  Feb  |  Mar  |Total Donated\n ","NAME","PHONE"
  6. printf "----------------------------------------------------------------\n"
  7. }
  8. {
  9. printf "%-20s%16s%.2d%.2d%.2d\n",$1,$2,$3,$4,$5;count = $3 + $4 + $5   + count
  10. }
  11. END{
  12. avg = count / NR
  13. printf "total :$%d\n",count
  14. printf "avg:$%d\n",avg
  15. }
复制代码
我的输出是这样的
  1. Mike Harrington       (510) 548-1278251017   
  2. Christian Dobbins     (408) 538-2358159020  
  3. total:971
  4. avg:485.5
复制代码
想不通哪里导致了$3 $4 $5没有输出,平台:centos 6.2  GNU Awk 3.1.7

论坛徽章:
0
2 [报告]
发表于 2012-02-14 18:27 |只看该作者
先排一下版,都是表情

论坛徽章:
0
3 [报告]
发表于 2012-02-14 18:32 |只看该作者
回复 2# yangkyo821


    已更改为代码模式

论坛徽章:
1
辰龙
日期:2014-05-22 11:38:58
4 [报告]
发表于 2012-02-14 19:14 |只看该作者
本帖最后由 winway1988 于 2012-02-14 19:14 编辑
BEGIN{
-F":"
printf "----------------------------------------------------------------\n"
printf "%-20s%-16s  Jan  |  Feb  |  Mar  |Total Donated\n ","NAME","PHONE"
printf "----------------------------------------------------------------\n"
}

-F":"这样写可以吗?

论坛徽章:
0
5 [报告]
发表于 2012-02-14 19:16 |只看该作者
本帖最后由 yangkyo821 于 2012-02-14 19:17 编辑
  1. [joe@joe-laptop ~]$ awk -F: '{printf "%-20s%-16s%3d %3d %3d\n",$1,$2,$3,$4,$5;total+=$3+$4+$5}END{printf "total:%d\navg:%g\n",total,total/NR}' lab5.data
  2. Mike Harrington      (510) 548-1278  250 100 175
  3. Christian Dobbins     (408) 538-2358  155  90 201
  4. Susan Dalsass        (206) 654-6279  250  60  50
  5. Archie McNichol      (206) 548-1348  250 100 175
  6. Jody Savage         (206) 548-1278   15 188 150
  7. Guy Quigley          (916) 343-6410  250 100 175
  8. total:2734
  9. avg:455.667
复制代码

论坛徽章:
1
辰龙
日期:2014-05-22 11:38:58
6 [报告]
发表于 2012-02-14 19:24 |只看该作者
  1. #!/bin/awk
  2. BEGIN{
  3.         FS=":";
  4.         printf "----------------------------------------------------------------\n"
  5.         printf "%-20s%-16s  Jan  |  Feb  |  Mar  |Total Donated\n ","NAME","PHONE"
  6.         printf "----------------------------------------------------------------\n"
  7. }
  8. {
  9.         printf "%-20s%16s%.2s%.2s%.2s\t%s\t%s\t%s\n",$1,$2,$3,$4,$5,$3,$4,$5;count = $3 + $4 + $5 + count
  10. }
  11. END{
  12.         avg = count / NR
  13.         printf "total :$%d\n",count
  14.         printf "avg:$%d\n",avg
  15. }
复制代码
lz的改了下

论坛徽章:
0
7 [报告]
发表于 2012-02-14 19:24 |只看该作者
回复 4# winway1988


    应该行,我在上个的awk的脚本就是这样写的,测试如下
tt.txt的内容间隔分别为空格,制表符,:号
  1. tet tet:ifjjj:1:2:5
  2. set set:ifjjj:3:4:3
  3. ret ret:irrrr:2:1:6
  4. rr      :j :hh  j
复制代码
test的脚本内容
  1. BEGIN{
  2. -F"[ :\t]"
  3. }
  4. {
  5. print $1,$2,$3,$4,$5
  6. }
复制代码
awk -f test tt.txt输出
  1. tet tet:ifjjj:1:2   
  2. set set:ifjjj:3:4   
  3. ret ret:irrrr:2:1   
  4. rr :j :hh j i
复制代码

论坛徽章:
1
辰龙
日期:2014-05-22 11:38:58
8 [报告]
发表于 2012-02-14 19:32 |只看该作者
回复 7# asplinux
  1. [root@winway ~]# cat file
  2. tet tet:ifjjj:1:2:5
  3. set set:ifjjj:3:4:3
  4. ret ret:irrrr:2:1:6
  5. rr      :j :hh  j
  6. [root@winway ~]# cat awkscr
  7. BEGIN{
  8. -F"[ :\t]"
  9. }
  10. {
  11. print $1"|"$2"|"$3"|"$4"|"$5
  12. }
  13. [root@winway ~]# awk -f awkscr file   
  14. tet|tet:ifjjj:1:2:5|||
  15. set|set:ifjjj:3:4:3|||
  16. ret|ret:irrrr:2:1:6|||
  17. rr|:j|:hh|j|
  18. [root@winway ~]#
复制代码
貌似有问题吧

论坛徽章:
0
9 [报告]
发表于 2012-02-14 19:37 |只看该作者
回复 8# winway1988


    原来如此,书上介绍的方法用的就是这样写的但都是直接在shell下写的,如5楼用的是我的写法在shell下写的,达到目的,但是写成脚本为什么就不行呢?

论坛徽章:
0
10 [报告]
发表于 2012-02-14 19:43 |只看该作者
回复 6# winway1988


    谢谢,确实可行,FS 与我用的F有区别吗?似乎都表示输入字段分隔符吧,在shell下将5楼的-F改为FS就达不到效果,
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP