awk 练习

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

上面的数据库中包含名字,电话号码和过去三个月里的捐款
1.显示所有电话号码
2.显示Dan的电话号码
3.显示Susan的名字和电话号码
4.显示所有以D开头的姓
5.显示所有以一个C或E开头的名
6.显示所有只有四个字符的名
7.显示所有区号为916的人名
8.显示Mike的捐款.显示每个值时都有以$开头.如$250$100$175
9.显示姓,其后跟一个逗号和名,如Jody,Savage
10.写一个awk的脚本,它的作用:
.显示Savage的全名和电话号码
.显示Chet的捐款
.显示所有头一个月捐款$250的人名.
注:区号本来是圆括号表示的。

 

 

 

answer

 

1、awk -F : '{print $2}' ll.txt

2、awk -F : '$1~/Dan/{print $2}' ll.txt

      awk -F : '/^Dan/{print $2}' ll.txt

3、awk -F : '/^Susan/{print $1,$2}' ll.txt

4、awk -F : '{print $1}' ll.txt |awk '{print $2}'|awk '/^D/'

5、awk -F : '{print $1}' ll.txt |awk '{print $2}'|awk '/^[CE]/'

6、awk -F : '{print $1}' ll.txt|awk '{if(length($1)==4) print $1}'

7、awk -F : '{print $1,$2}' ll.txt|awk '{if($3=="[916]")print $1,$2}'

     awk -F: '/\[916\]/{print $1}' datafile

8、awk -F: '/^Mike/{print "$"$3,"$"$4,"$"$5}' ll.txt

9、awk -F: '{print $1}' ll.txt |awk '{print $1","$2}'

10、

     BEGIN{FS=":"}

    {if($1 ~/ Savage/) print $1":"$2}
    {if($1 ~/^Chet /) print "$"$3"$"$4"$"$5}
    {if($3 == 250) print $1}

    awk -f aa.awk ll.txt

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值