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

### 关于 `awk` 的练习题与解析 以下是几个典型的 `awk` 练习题目及其对应的代码实现和解析: #### 题目一:统计文件中的总行数 假设有一个名为 `data.txt` 的文件,每行为一条记录。 ```bash awk 'END {print NR}' data.txt ``` 这段代码通过内置变量 `NR`(Number of Records),在处理完所有数据后,在 `END` 块中打印出总的行数[^1]。 --- #### 题目二:计算特定列的平均值 给定一个 CSV 文件 `grades.csv`,其中第二列表示学生的成绩,求这些成绩的平均值。 ```bash awk -F ',' '{sum += $2} END {print "Average:", sum/NR}' grades.csv ``` 此脚本设置字段分隔符为逗号 `-F ','`,遍历每一行并将第二列的成绩累加到变量 `sum` 中。最后在 `END` 块中输出平均值[^2]。 --- #### 题目三:过滤并显示符合条件的数据 对于日志文件 `access.log`,筛选出 HTTP 状态码为 404 的请求,并仅显示其 URL 和状态码。 ```bash awk '$9 ~ /404/ {print $7, $9}' access.log ``` 这里 `$9` 表示第九列(通常存储的是 HTTP 状态码)。如果该列匹配正则表达式 `/404/`,就打印第七列(URL)以及第九列的状态码。 --- #### 题目四:引入外部变量进行动态操作 假设有如下需求:读取环境变量 `threshold=80` 并将其作为阈值来判断学生成绩是否合格。 ```bash threshold=80 awk -v limit="$threshold" -F ',' '$2 >= limit {print $1, "passed"}' grades.csv ``` 上述命令利用 `-v` 参数将 shell 变量传递至 `awk` 脚本内部,从而实现了动态比较逻辑[^3]。 --- #### 题目五:使用控制结构完成复杂任务 创建一个简单的程序,用于查找数组中最大值的位置及数值本身。 ```bash echo "10 20 5 30" | awk ' { max = $1; pos = 1; for (i = 2; i <= NF; i++) { if ($i > max) { max = $i; pos = i; } } } END { print "Max value is", max, "at position", pos }' ``` 在此例子中,我们定义了一个循环迭代整个输入行的所有字段 (`NF`) 来找到最大的那个数字及其索引位置[^4]。 --- ### 提供的学习资源建议 除了以上实例外,还可以参考官方文档或者在线教程进一步深入理解 `awk` 功能特性。例如 GNU Awk 用户指南提供了详尽说明,适合初学者逐步掌握高级技巧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值