*****awk命令练习(转自sir)

*****awk命令练习(转自sir)

awk命令练习.
文件: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的人名.
注:区号本来是圆括号表示的.
居然没有答案,我现在正缺这些资料啊,楼主不厚道
[quote:f852b496b1="atfa"]居然没有答案,我现在正缺这些资料啊,楼主不厚道[/quote]急了吧,呵呵
书到用时方恨少啊
哈哈,答案我整理了一份,但是总不能大家都没做就给出答案吧
做做看
[quote:df2b512339="atfa"]居然没有答案,我现在正缺这些资料啊,楼主不厚道[/quote]
自己作     
awk命令练习.
文件: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的人名.

1.cat awk|awk -F: '{print $2}'
2.cat awk|awk -F: '/Dan/{print $2}'
3.cat awk|awk -F: '/Susan/{print $1,$2}'
4.cat awk|awk '$2~/^D/{print $2}'
5.cat awk|awk '/^[C|E]/{print $1}'
6.cat awk|awk 'length($1)==4{print $1}'
7.cat awk|awk -F: '$2~/\[916\]/{print $1}'
8.cat awk|awk -F: '/Mike/{print "$"$3"$"$4"$"$5}'
9.cat awk|awk -F: '{print $1}'|awk '{print $2","$1}'
10.
cat awkscript
[code:1]
#this is awk script
/Savage/{print $1,$2}
/Chet/{print $3,$4,$5}
{if($3==250)print $1}
[/code:1]
awk -F: -f awkscript awk