环境
RedHat Linux 9 + VWWare 8.0 + SSH 3.2.9
任务
下面的文本中包含名字、电话和为党派运动捐款的数额。
名字:电话:1月捐款情况:2月捐款情况:3月捐款情况
Mike Harrington :(510) 548-1278:250:100:175
Christian Dobbins:(408) 538-2358:155:90:201
Susan Dalsass:(206) 654-6279:250:60:50
Archie McNichol:(206) 548-1348:250:100:175
Jody Savage: (206) 548-1278:15:188:150
Guy Quigley:(916) 343-6410:250: 100:175
Dan Savage:(406) 298-7744:450:300:275
NancyMcNeil:(206) 548-1278:250:80:75
John Goldenrod:(916) 348-4278:250:100:175
Chet Main:(510) 548-5258:50:95:135
Tom Savage:(408) 926-3456:250:168:200
Elizabeth Stachelin:(916)440-1763:175:75:300
使用你能用到的任何linux命令脚本产生一个如下的报告,注意,报告中的summery包含对于捐款情况的一些统计信息。
解决
awk -F ":" 'BEGIN{
print " ***FIRST QUARTERLY REPORT **** \n";
print " ***CAMPAIGN 2000 CONTRIBUTIONS ***\n";
print "-------------------------------------------------------------------\n";
print " NAME PHONE JAN| Feb| Mar| Total Danated \n";
print "-------------------------------------------------------------------\n";
}
BEGIN{sum=0;total=0;average=0;i=0;highest=0;name;biaozhun=500;firstNames[12];count=0;lastNames[12];person[12]}
{for(i=0;i<NR;i++){person[i]=$1}}
{total=$3+$4+$5;sum+=total;average=sum/12;}
{if(total>highest) highest=total;if(highest == total)name=$1;}
{if(total>biaozhun){firstNames[count]=$1;lastNames[count]=$2;count++;}}
{printf("%-20s%12s%5d%5d%5d\t%5d\n",$1,$2,$3,$4,$5,total);}
END{
print "-------------------------------------------------------------------\n";
print " SUMMARY \n";
print "-------------------------------------------------------------------\n";
printf("The campaign received a total of $%d for this quartor\n",sum);
printf("The average donation for the %d contributors was $%.2f.\n",NR,average);
printf("The highest total contribution was $%.2f made by %s\n",highest,name);
printf(" ***THANKS Dan*** \n");
printf("The following people donated over \$500 to the campaign \n");
printf("They are eligible for the quarterly drawing!! \n");
printf("Listed are their names (sorted by last names) and phone numbers: \n");
{OFS="--";$1="\t"$1;}
for(i=0;i<count;i++) {print firstNames[i],lastNames[i] | "sort -k 2"};
printf(" Thanks to all of you for your continued support!! \n");
}
' salary.txt
运行效果截图
参考资料
AWK使用练习
http://blog.csdn.net/wentasy/article/details/8220224
问题提出
这句话(Thanks to all of you for your continued support!! )打印在for之前,for里面有变量就会出现这种情况,for里面只打印纯文本的话就不会出现这个情况。求解释。
分享到:
相关推荐
第一章 UNIX AWK使用手册(第二版)......................................................................................5 1.1 什么是AWK?...................................................................
awk学习awk学习awk学习awk学习awk学习awk学习awk学习
awk ‘/101/’ file 显示文件file中包含101的匹配行。 awk ‘/101/,/105/’ file awk ‘$1 == 5′ file awk ‘$1 == “CT”‘ file 注意必须带双引号 awk ‘$1 * $2 >100 ‘ file awk ‘$2 >5 && $2<=15' file
与sed和grep很相似,awk是一种样式扫描与处理工具。但其功能却大大强于sed和grep。awk提供了极其强大的功能:它几乎可以完成grep和sed所能完成的全部工作,同时,它还可以可以进行样式装入、流控制、数学运算符、...
1 Linux主要shell命令详解 2 Linux bash shell脚本语法入门 3 Shell基本命令 4 使用 sed 编辑器
AWK 详细使用文档 AWK 详细使用文档 AWK 详细使用文档
这是一本awk学习指引, 其重点着重于 : awk 适于解决哪些问题 ? awk 常见的解题模式为何 ? 为使读者快速掌握awk解题的模式及特性, 本手册系由一些较具代表性的范例及其题解所构成; 各范例由浅入深, 彼此间相互...
你可能对UNIX比较熟悉,但你可能对awk很陌生,这一点也不奇怪,的确,与其优秀的功能相比,awk还远没达到它应有的知名度。awk是什么?与其它大多数UNIX命令...正是这三个人创造了awk---一个优秀的样式扫描与处理工具
awk 实例入门 教程 AWK_样式扫描和处理语言
你可能对UNIX比较熟悉,但你可能对awk很陌生,这一点也不奇怪,的确,与其优秀的功能相比,awk还远没达到它应有的知名度。awk是什么?与其它大多数UNIX命令...正是这三个人创造了awk---一个优秀的样式扫描与处理工具。
awk参考资料, awk参考资料详情.
由于是88年的老书,其中对gawk最新版本对awk的扩展没有提及,但这并不妨碍其称为一本经典。可以配合Arnold Robbins的Effective AWK Programming, 3rd edition, 2001一起阅读以了解gawk的最新状态。 (来自: 老好人...
因为遇到了awk问题,所以找到这个小结,共享一下
利用tcpdump抓包和awk处理写的基于端口的流量统计
awk 是一门编程语言,它的基本操作是在一组文件上查找模式,并在包含这些模式实例的那 些行或字段上进行指定的动作。awk 使得特定数据的选择和变换操作更易于表达
awk用法小结 - - - by ruson 2006.4 NTU 1. awk非常适合于结构化的文本文件(行、列数据)复杂处理。相对于sed而言,它可进行复杂的编程处理,并且可以产生复杂的报表输出。 2. awk通常有三个版本,旧awk、nawk...
Awk是为高级文本处理而设计的通用脚本语言。...Awk一次对一条记录进行操作,直到到达输入的末尾。记录由一个称为记录分隔符的字符分隔。默认的记录分隔符是换行符,这意味着文本数据中的每一行都是一个记录。
精通awk命令 Unix awk使用手册.htm awk.pdf
awk的详细介绍,awk的使用介绍,awk的使用教程,awk的学习宝典
awk详解awk详解awk详解awk详解awk详解awk详解awk详解awk详解awk详解