awk练习-正则表达式

来源:互联网 发布:流程图绘制软件下载 编辑:程序博客网 时间:2024/04/30 03:50

awk练习-正则表达式

分类: Shell 308人阅读 评论(0)收藏 举报

% cat lab3.data

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.显示所有电话号码

[vb] view plaincopy
  1. % awk -F: '{print $2}' lab3.data  
  2. (510) 548-1278  
  3. (408) 538-2358  
  4. (206) 654-6279  
  5. (206) 548-1348  
  6. (206) 548-1278  
  7. (916) 343-6410  
  8. (406) 298-7744  
  9. (206) 548-1278  
  10. (916) 348-4278  
  11. (510) 548-5258  
  12. (408) 926-3456  
  13. (916) 440-1763  
 


2.显示Dan的电话号码

[vb] view plaincopy
  1. [~]$ awk -F: '/Dan/{print $2}' lab3.data  
  2. (406) 298-7744  
 


3.显示Susan的名字和电话号码

[vb] view plaincopy
  1. [~]$ awk -F: '/Susan/{print $1, $2}' lab3.data  
  2. Susan Dalsass (206) 654-6279  
 


4.显示所有以D开头的姓

[vb] view plaincopy
  1. [~]$ awk -F"[ :]" '$2 ~/^D/{print $2}' lab3.data  
  2. Dobbins  
  3. Dalsass  
 


5.显示所有以一个C或E开头的名

[vb] view plaincopy
  1. [~]$ awk '$1 ~/^[CE]/{print $1}' lab3.data  
  2. Christian  
  3. Chet  
  4. Elizabeth  
 


6.显示所有只有四个字符的名

[vb] view plaincopy
  1. [~]$ awk '$1 ~/[A-Z][a-z][a-z][a-z]$/{print $1}' lab3.data  
  2. Mike  
  3. Jody  
  4. John  
  5. Che  
 


7.显示所有区号为916的人名

[c-sharp] view plaincopy
  1. [~]$ awk -F: '$2 ~/(916)/{print $1}' lab3.data  
  2. Guy Quigley  
  3. John Goldenrod  
  4. Elizabeth Stachelin  
 


8.显示Mike的捐款.显示每个值时都有以$开头.如$250$100$175

[vb] view plaincopy
  1. [~]$ awk -F: '$1 ~/Mike/{print $1 ": ""$"$3"$"$4"$"$5}' lab3.data  
  2. Mike Harrington: $250$100$175  
 


9.显示姓,其后跟一个逗号和名,如Jody,Savage

[vb] view plaincopy
  1. [~]$ awk -F"[ :]" '{print $2","$1}' lab3.data  
  2. Harrington,Mike  
  3. Dobbins,Christian  
  4. Dalsass,Susan  
  5. McNichol,Archie  
  6. Savage,Jody  
  7. Quigley,Guy  
  8. Savage,Dan  
  9. McNeil,Nancy  
  10. Goldenrod,John  
  11. Main,Chet  
  12. Savage,Tom  
  13. Stachelin,Elizabeth  
 


10.写一个awk的脚本,它的作用:
.显示Savage的全名和电话号码
.显示Chet的捐款
.显示所有头一个月捐款$250的人名.

[vb] view plaincopy
  1. [~]$ cat awk_prac  
  2. #List Savage full name and Tel No.  
  3. #List Chet donation amount.  
  4. #List names of $250 donation in first month.  
  5. /Savage/{print $1": "$2}  
  6. /Chet/{print $1": ""$"$3", $"$4", $"$5}  
  7. $3 ~/250/{print $1}  
  8. [~]$  
  9. [~]$  
  10. [~]$ awk -f awk_prac -F: lab3.data  
  11. Jody Savage: (206)548-1278  
  12. Dan Savage: (406)298-7744  
  13. Tom Savage: (408)926-3456  
  14. Chet Main: $50, $95, $135   
  15. Mike Harrington  
  16. Susan Dalsass  
  17. Archie McNichol  
  18. Guy Quigley  
  19. Nancy McNeil  
  20. John Goldenrod  
  21. Tom Savage 

原创粉丝点击