AWK使用练习

环境

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包含对于捐款情况的一些
统计信息。

 

 

 

解决

 

 

#!/bin/bash
#filename:test.sh
sourcename=$1
echo "$sourcename"
sed -i "s/: /:/g" sourcename 
echo "             ***FIRST QUARTERLY REPORT **** "
echo "            ***CAMPAIGN 2000 CONTRIBUTIONS ***"
echo "-------------------------------------------------------------------"
echo "  NAME                   PHONE      JAN| Feb| Mar|   Total Danated "
echo "-------------------------------------------------------------------"
awk -F: '{printf( "%-20s%12s%5d%5d%5d\t%5d\n",$1,$2,$3,$4,$5,$3+$4+$5) } ' linux2.txt
echo "-------------------------------------------------------------------"
echo "                       SUMMARY                                     "
echo "-------------------------------------------------------------------"
awk -F: 'BEGIN{sum=0;total=0} {total=$3+$4+$5;sum+=total} END {
	printf("The campaign received a total of $%d for this quartor\n",sum)
	}' linux2.txt
awk -F: 'BEGIN{average=0;i=0;total=0;sum=0} {total=$3+$4+$5;sum+=total;i++}
	END {average=sum/i;printf("The average donation for the %d contributors was $%.2f.\n",i,average) }' linux2.txt
awk -F: 'BEGIN{highest=0;sum=0;total=0;name} {
	total=$3+$4+$5;if(total> highest) {highest=total;name=$1}} END {
	printf("The highest total contribution was $%.2f made by %s\n",highest,name) }' linux2.txt

echo "                   ***THANKS Dan***                               "
echo "The following people donated over \$500 to the campaign           "
echo "They are eligible for the quarterly drawing!!                     "
echo "Listed are their names (sorted by last names) and phone numbers:  "
awk -F: 'BEGIN{ OFS="--";biaozhun=500;total=0} {
	$1="\t"$1;total=$3+$4+$5;if(total>biaozhun) print $1,$2 | "sort -k 2" }' linux2.txt 
echo "		Thanks to all of you for your continued support!!       "


 

 

运行效果

 

 

 

 

 

 

 

 

 

参考资料

linux awk 内置函数详细介绍(实例)

http://www.cnblogs.com/chengmo/archive/2010/10/08/1845913.html

 

Awk学习笔记
http://man.lupaworld.com/content/manage/ringkee/awk.htm

### 回答1: 1. 使用awk命令,将一个文件中的第一列和第二列相加,并输出结果。 2. 使用sed命令,将一个文件中的所有空行删除,并输出结果。 3. 使用grep命令,查找一个文件中包含特定字符串的行,并输出结果。 4. 使用awk命令,将一个文件中的所有行按照第二列进行排序,并输出结果。 5. 使用sed命令,将一个文件中的所有单词转换为大写,并输出结果。 6. 使用grep命令,查找一个文件中不包含特定字符串的行,并输出结果。 7. 使用awk命令,将一个文件中的所有行按照第一列进行分组,并输出结果。 8. 使用sed命令,将一个文件中的所有行反转,并输出结果。 9. 使用grep命令,查找一个文件中包含特定字符串的行数,并输出结果。 10. 使用awk命令,将一个文件中的所有行按照第三列进行筛选,并输出结果。 ### 回答2: awk、sed和grep是Linux系统中常见的文本处理工具,它们可以对文本进行搜索、替换、过滤、格式化等操作。以下是一些常见的练习题,可以帮助读者加深对这些工具的理解和掌握它们的使用技巧。 1. 使用awk命令统计日志文件中每个IP的访问次数。 awk '{a[$1]++} END {for(i in a) print i, a[i]}' logfile 其中,a[$1]++用于统计IP的访问次数,END子句用于在处理完整个文件后输出结果。 2. 使用sed命令批量重命名文件夹中所有的.jpg文件为.png。 sed -i 's/\.jpg/\.png/g' $(find /path/to/folder -type f -name '*.jpg') 其中,-i选项表示直接修改原文件,使用find命令来查找所有.jpg文件,并将其替换为.png。 3. 使用grep命令查找一个目录下所有包含“Linux”关键字的文件,并输出匹配结果。 grep -r "Linux" /path/to/directory 其中,-r选项表示递归查找所有文件,如果找到匹配项,则会输出所在的文件名和匹配的行。 4. 使用awk命令从一组数字中找出最大值和最小值,并计算它们的平均数。 echo "1 2 3 4 5" | awk 'BEGIN {max=0;min=999999} {for(i=1;i<=NF;i++) if($i>max) max=$i;else if($i<min) min=$i;total+=$i} END {print "Max:",max,"Min:",min,"Avg:",total/NF}' 其中,BEGIN子句用于初始化max和min变量,NF表示输入行的字段数量,END子句用于计算平均数。 以上是关于awk、sed和grep的基础练习题,掌握了这些基本操作后,读者可以尝试更复杂的文本处理任务,如去重、排序、计数等。同时,多查阅相关文档和资料,不断练习,可以更好地掌握这些工具。 ### 回答3: awk、sed、grep三者是Linux中常用的文本处理命令,它们都可以用来处理大量的文本信息。下面是一些实践练习。 1. 使用grep 给定一个文件file.txt,其中的每行都是一个字符串,找出其中包含字符串“hello”的所有行并输出到一个新的文件new.txt。 grep "hello" file.txt > new.txt 2. 使用awk 给定一个包含三列的文件file.txt(英语、数学和科学的成绩),找出其中科学成绩大于80分的所有学生。 awk '$3>80{print $0}' file.txt 3. 使用sed 给定一个文件file.txt,其中有若干行英文句子,将其中所有的小写字母转换为大写字母。 sed 's/[a-z]/\U&/g' file.txt 4. 使用grep和awk 给定一个包含多个文件的目录dir,找出其中含有文件名“error.log”的文件,并统计各个文件中“error”单词出现的总次数。 grep -l "error.log" dir/* | xargs awk '{count +=gsub(/error/,"&")}END{print count}' 以上是一些常用的练习题,可以帮助大家熟悉和掌握这些常用命令的使用方法。需要注意的是,在实践过程中,应该多加尝试,有问题及时查阅相关文档或寻求帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值