文件:datafile
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
?
?awk命令练习
上面的数据库中包含名字,电话号码和过去三个月里的捐款
1.显示所有电话号码
awk -F":| "  ‘{print $4}‘  datafile
2.显示Dan的电话号码
awk -F":| "  ‘$1=="Dan"{print $4}‘  datafile 
3.显示Susan的名字和电话号码
awk -F":| "  ‘$1=="Susan"{print $1,$4}‘  datafile 
4.显示所有以D开头的姓
awk -F":| "  ‘/^[D]/‘  datafile
5.显示所有以一个C或E开头的名
awk -F":| "  ‘/^[CE]/{print $1}‘  datafile 
6.显示所有只有四个字符的名
awk -F":| "  ‘{if(length($1)==4){print $1}}‘  datafile
7.显示所有区号为916的人名
awk -F":| "  ‘$3=="[916]"{print $1}‘  datafile
8.显示Mike的捐款.显示每个值时都有以$开头,如$250$100$175
awk -F":| "  ‘$1=="Mike"{print "$"$5"$"$6"$"$7}‘  datafile
9.显示姓,其后跟一个逗号和名,如Jody,Savage
awk -F":| "  ‘{print $1","$2}‘  datafile 
10.写一个awk的脚本,它的作用:
显示Savage的全名和电话号码
显示Chet的捐款
显示所有头一个月捐款$250的人名。
注:区号本来是圆括号表示的。
#!/bin/bash
file=datafile
awk -F" |:" ‘$2=="Savage"{print $1,$2,$4}‘  $file
awk -F" |:" ‘$1=="Chet"{print "$"$5"$"$6"$"$7}‘  $file
awk  -F" |:" ‘$5=="250"{print $1}‘  $fileawk基本练习
原文:http://blog.51cto.com/13587169/2070383