做了幾道簡單的awk基礎練習題,跟大家分享一下
文件 file.txt的內容格式:
文件中包含名字,電話號碼和過去三個月裡的捐款
具體內容如下:
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
[root@localhost zhaoyj]#
awk -F: '{print $2}' file.txt 2
[root@localhost zhaoyj]#
awk -F: '$1~/Dan/{print $2}' file.txt [406] 298-7744
3
[root@localhost zhaoyj]#
awk -F: '$1~/Susan/{print$1":"$2}' file.txt Susan Dalsass:[206] 654-6279
4
[root@localhost zhaoyj]#
awk '$1~/^D/{print $1}' file.txt Dan
5
[root@localhost zhaoyj]#
awk -F: '$1~/^[C|E]/{print $1}' file.txt |awk '{print $2}'Dobbins
Main
Stachelin
6
[root@localhost zhaoyj]#
awk 'length($1)=="4"{print $1}' file.txt Mike
Jody
John
Chet
7
[root@localhost zhaoyj]#
awk -F"[ :]" '$3~/916/{print $1" "$2}' file.txt Guy Quigley
John Goldenrod
Elizabeth Stachelin
8
[root@localhost zhaoyj]#
awk -F: '$1~/Mike/{print "$"$3" ""$"$4" ""$"$5}' file.txt $250 $100 $175
9
[root@localhost zhaoyj]#
awk -F: '{print $1}' file.txt |awk '{print $1","$2}'10 這個沒有以腳本的形式寫出來,直接用命令形式寫的