题目数据如下:

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
Nancy McNeil:(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

上面这个数据库的记录内容包括姓名、电话号码和最近3个月的竞选捐款数额。
.打印在第二个月捐款超过100美元的人的姓和名。
awk -F: '$4>100{print $1}' lab3.data
.打印在最后一个月捐款少于85美元的人的姓名和电话号码
awk -F: '$5<85{print $1,$2}' lab3.data
.打印第一个月捐款额在75~150美元之间的人。
awk -F: '$5>=75 && $5<=150 {print $1}' lab3.data
.打印这3个月的捐款总额不超过800美元的人。
awk -F: '$3+$4+$5 <= 800 {print $1}' lab3.data
.打印月均捐款额大于200美元的人的姓名和电话号码。
awk -F: '$3+$4+$5 > 600{print $1,$2}' lab3.data
.打印不在916区的人的姓。
awk -F"[ :]" '$3 !~ "916"{print $2}' lab3.data
.打印每条记录,并在记录前加上其记录号。
awk '{print NR,$0}' lab3.data
.打印每个人的姓名和捐款总额。
awk -F: '{print $1,$3+$4+$5}' lab3.data
.把Chet第二个月的捐款额加上10
awk -F: '/Chet/{$4=$4+10} {print $0}' lab3.data
.把 Nancy McNeil的名字改成Louise McInnes
awk -F: '/Nancy McNeil/{$1="Louise Mclnnes"} {print}' lab3.data

11.写出一个awk脚本输出以下信息

                       ***CAMPAIGN  CONTRIBUTIONS***
--------------------------------------------------------------------------------
NAME PHONE Jan | Feb | Mar | Total Donated
--------------------------------------------------------------------------------
Mike Harrington () - 250.00 100.00 175.00 525.00
Christian Dobbins () - 155.00 90.00 201.00 446.00
Susan Dalsass () - 250.00 60.00 50.00 360.00
Archie McNichol () - 250.00 100.00 175.00 525.00
Jody Savage () - 15.00 188.00 150.00 353.00
Guy Quigley () - 250.00 100.00 175.00 525.00
Dan Savage () - 450.00 300.00 275.00 1025.00
Nancy McNeil () - 250.00 80.00 75.00 405.00
John Goldenrod () - 250.00 100.00 175.00 525.00
Chet Main () - 50.00 95.00 135.00 280.00
Tom Savage () - 250.00 168.00 200.00 618.00
Elizabeth Stachelin () - 175.00 75.00 300.00 550.00
--------------------------------------------------------------------------------
SUMMARY
--------------------------------------------------------------------------------
The campaign received a total of $6137.00 for this quarter.
The average donation for the conrtibutors was $511.42.
The highest contribution was $450.00.
The lowest contribution was $15.00.
$ cat lab3.awk
#!/usr/bin/awk -f BEGIN{
FS=":"
print " ***CAMPAIGN 1998 CONTRIBUTIONS***"
print "--------------------------------------------------------------------------------"
print "NAME PHONE Jan | Feb | Mar | Total Donated"
print "--------------------------------------------------------------------------------"
min=1000.0
max=
total=
}
{
total+=$+$+$
if($<min)
min=$
if($<min)
min=$
if($<min)
min=$
if($>max)
max=$
if($>max)
max=$
if($>max)
max=$
printf "%-20s%14s %-6.2f %-6.2f %-6.2f %-6.2f\n",$,$,$,$,$,$+$+$
}
END{
print "--------------------------------------------------------------------------------"
print " SUMMARY "
print "--------------------------------------------------------------------------------"
printf "The campaign received a total of $%6.2f for this quarter.\n",total
printf "The average donation for the 12 conrtibutors was $%5.2f.\n",total/12.0
printf "The highest contribution was $%5.2f.\n",max
printf "The lowest contribution was $%4.2f.\n",min
}

awk练习笔记的更多相关文章

  1. linux awk学习笔记

    awk学习笔记 awk语法格式 awk '{pattern + action}' {filenames} awk作用 awk的最基本功能是在文件或者字符串中基于指定规则浏览和抽取信息,awk抽取信息后 ...

  2. 【转】awk学习笔记

    Awk学习笔记 整理:Jims of 肥肥世家 <jims.yang@gmail.com> Copyright © 2004 本文遵从GPL协议,欢迎转载.修改.散布. 第一次发布时间:2 ...

  3. awk 学习笔记

    awk的语法有两种形式 awk [options] 'script' var=value file(s) awk [options] -f scriptfile var=value file(s) 选 ...

  4. sed、grep、awk -- 三剑客笔记记录

    sed常用操作笔记   1.删除文件最后一行: sed -i '$d' filename 2.递归替换内容:sed -i 's/内容A/内容B/g' filename sed -i "s/S ...

  5. sed and awk学习笔记

    sed and awk 背景 awk起源追溯至sed和grep,进而追溯至共同的行编辑器ed.实用工具grep来源于ed命令:g/re/p .实用工具awk和sed有一个共同的选项-f用于指定脚本的名 ...

  6. awk学习笔记二:调用shell、文件执行(转)

    awk 'BEGIN {print "Hello"}' 不操作文件直接处理数据流 要调用shell则可以用管道命令 如,打印日期awk 'BEGIN {"date&quo ...

  7. awk学习笔记一:基础(转)

    awk内置变量 ARGC 命令行参数个数ARGV 命令行参数排列ENVIRON 支持队列中系统环境变量的使用FILENAME awk浏览的文件名FNR 浏览文件的记录数FS 设置输入域分隔符,等价于命 ...

  8. 【转】 awk 学习笔记

    本文参考的是 ubuntu 下 gawk version 3.1.6 以及 <sed&awk> 一 . awk 简介 awk 是一种解释型(tawk除外)文本处理语言 二 . aw ...

  9. AWK读书笔记

    1.awk 'parttern {action}' filename 从文件中逐行读取并匹配parttern,若匹配成功执行action否则读取下一行. parttern和action都可选,若省略p ...

随机推荐

  1. [Asp.net mvc]Asp.net mvc 使用Json传递数据

    在之前的练习中一直是直接传递的Model到后台或是单个数据到后台,今天在使用中遇到了点问题,不能使用Model传递到后台,但又要实现多个数据到后台,实验了多次有了以下的解决方案,给自己留个笔记. 功能 ...

  2. C# 获取两个时间段之间的所有时间与获取当前时间所在的季度开始和结束时间

    一:C# 获取两个时间段之间的所有时间 public List<string> GetTimeList(string rq1, string rq2) { List<string&g ...

  3. 关于UIScrollView有些你很难知晓的崩溃情形

    关于UIScrollView有些你很难知晓的崩溃情形 为了实现以下的功能(按钮之间的切换效果): 简短的代码如下: // // RootViewController.m // BUG // // Co ...

  4. Linux file命令详解

    file: 查看文件类型 file常见命令参数 Usage: file [OPTION...] [FILE...] Determine type of FILEs. --help display th ...

  5. win8中 cmd直接以管理员权限运行

    一.组合键 WIN+X   二.锁定到任务栏,方便以后快速启动     三.控制面板->控制中心     四.更改用户账户控制设置--调到最低 好了,点击任务栏的命令提示符

  6. python -wordcloudan云词安装

    1安装网站:https://download.lfd.uci.edu/pythonlibs/u2yrk7ps/wordcloud-1.4.1-cp36-cp36m-win_amd64.whl 2安装过 ...

  7. 归并排序(php实现)

    <?php function mergeSort(&$arr){ $len = count($arr); msort($arr,0,$len-1); } function msort(& ...

  8. oracle查看用户属于哪个表空间

    select username,default_tablespace from dba_users  where username='用户名';

  9. 经验总结13--EF配置

    EF配置,开发前的准备及步骤. 使用V22013和EF6.1. 1.使用VS新建MVC项目. 2.创建实体类. 3.配置web.config的数据库链接字符串. <connectionStrin ...

  10. linux下添加用户到sudo组 并禁止sudo用户修改密码

    linux下添加用户到sudo组 创建用户  useradd hanli 为新用户设置密码  passwd hanli 创建用户组  groupadd  op 将用户添加到用户组  usermod - ...