grep awk sed練習

 


1、grep命令練習 
文件:datafile 
Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300 
Betty Boop:245-836-8357:635 Cutesy Lane, Hollywood, CA 91464:6/23/23:14500 
Igor Chevsky:385-375-8395:3567 Populus Place, Caldwell, NJ 23875:6/18/68:23400 
Norma Corder:397-857-2735:74 Pine Street, Dearborn, MI 23874:3/28/45:245700 
Jennifer Cowan:548-834-2348:583 Laurel Ave., Kingsville, TX 83745:10/1/35:58900 
Jon DeLoach:408-253-3122:123 Park St., San Jose, CA 04086:7/25/53:85100 
Karen Evich:284-758-2857:23 Edgecliff Place, Lincoln, NB 92086:7/25/53:85100 
Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200 
Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200 
Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900 
Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900 
Lori Gortz:327-832-5728:3465 Mirlo Street, Peabody, MA 34756:10/2/65:35200 
Paco Gutierrez:835-365-1284:454 Easy Street, Decatur, IL 75732:2/28/53:123500 
Ephram Hardy:293-259-5395:235 CarltonLane, Joliet, IL 73858:8/12/20:56700 
James Ikeda:834-938-8376:23445 Aster Ave., Allentown, NJ 83745:12/1/38:45000 
Barbara Kertz:385-573-8326:832 Ponce Drive, Gary, IN 83756:12/1/46:268500 
Lesley Kirstin:408-456-1234:4 Harvard Square, Boston, MA 02133:4/22/62:52600 
William Kopf:846-836-2837:6937 Ware Road, Milton, PA 93756:9/21/46:43500 
Sir Lancelot:837-835-8257:474 Camelot Boulevard, Bath, WY 28356:5/13/69:24500 
Jesse Neal:408-233-8971:45 Rose Terrace, San Francisco, CA 92303:2/3/36:25000 
Zippy Pinhead:834-823-8319:2356 Bizarro Ave., Farmount, IL 84357:1/1/67:89500 
Arthur Putie:923-835-8745:23 Wimp Lane, Kensington, DL 38758:8/31/69:126000 
Popeye Sailor:156-454-3322:945 Bluto Street, Anywhere, USA 29358:3/19/35:22350 
Jose Santiago:385-898-8357:38 Fife Way, Abilene, TX 39673:1/5/58:95600 
Tommy Savage:408-724-0140:1222 Oxbow Court, Sunnyvale, CA 94087:5/19/66:34200 
Yukio Takeshida:387-827-1095:13 Uno Lane, Ashville, NC 23556:7/1/29:57000 
Vinh Tranh:438-910-7449:8235 Maple Street, Wilmington, VM 29085:9/23/63:68900 

1. 顯示全部包含San的行 
2.顯示全部以J開始的人名所在的行 
3.顯示全部以700結尾的行 
4.顯示全部不包括834的行 
5.顯示全部生日在December的行 
6.顯示全部電話號碼的區號爲498的行 
7.顯示全部這樣的行:它包含一個大寫字母,後跟四個小寫字母,一個冒號,一個空格,和一個大寫字母 
8.顯示姓以K或k開頭的行 
9.顯示工資爲六位數的行,並在前面加行號 
10.顯示包括Lincoln或lincoln的行,而且grep對大小寫不敏感. 

1.grep "San" datafile 
2.grep '^J' datafile 
3.grep '700$' datafile 
4.grep -v "834" datafile 
5.grep '\:12\/' datafile 
6.grep '\:498\-' datafile #是否是做者寫錯了,好象沒有這樣的行 
7.grep '[A-z][a-z]\{4\}\:[[:space:]][A-Z]' datafile #好象也沒有這樣的行,或者個人不對^_^ 
8. grep '[a-z]\{1,\}[[:space:]][Kk]' datafile 
9.grep -n '[0-9]\{6,\}$' datafile 
10.grep -i "lincoln" datafile
 

二.sed命令大練習 
文件:datafile 
Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300 
Betty Boop:245-836-8357:635 Cutesy Lane, Hollywood, CA 91464:6/23/23:14500 
Igor Chevsky:385-375-8395:3567 Populus Place, Caldwell, NJ 23875:6/18/68:23400 
Norma Corder:397-857-2735:74 Pine Street, Dearborn, MI 23874:3/28/45:245700 
Jennifer Cowan:548-834-2348:583 Laurel Ave., Kingsville, TX 83745:10/1/35:58900 
Jon DeLoach:408-253-3122:123 Park St., San Jose, CA 04086:7/25/53:85100 
Karen Evich:284-758-2857:23 Edgecliff Place, Lincoln, NB 92086:7/25/53:85100 
Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200 
Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200 
Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900 
Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900 
Lori Gortz:327-832-5728:3465 Mirlo Street, Peabody, MA 34756:10/2/65:35200 
Paco Gutierrez:835-365-1284:454 Easy Street, Decatur, IL 75732:2/28/53:123500 
Ephram Hardy:293-259-5395:235 CarltonLane, Joliet, IL 73858:8/12/20:56700 
James Ikeda:834-938-8376:23445 Aster Ave., Allentown, NJ 83745:12/1/38:45000 
Barbara Kertz:385-573-8326:832 Ponce Drive, Gary, IN 83756:12/1/46:268500 
Lesley Kirstin:408-456-1234:4 Harvard Square, Boston, MA 02133:4/22/62:52600 
William Kopf:846-836-2837:6937 Ware Road, Milton, PA 93756:9/21/46:43500 
Sir Lancelot:837-835-8257:474 Camelot Boulevard, Bath, WY 28356:5/13/69:24500 
Jesse Neal:408-233-8971:45 Rose Terrace, San Francisco, CA 92303:2/3/36:25000 
Zippy Pinhead:834-823-8319:2356 Bizarro Ave., Farmount, IL 84357:1/1/67:89500 
Arthur Putie:923-835-8745:23 Wimp Lane, Kensington, DL 38758:8/31/69:126000 
Popeye Sailor:156-454-3322:945 Bluto Street, Anywhere, USA 29358:3/19/35:22350 
Jose Santiago:385-898-8357:38 Fife Way, Abilene, TX 39673:1/5/58:95600 
Tommy Savage:408-724-0140:1222 Oxbow Court, Sunnyvale, CA 94087:5/19/66:34200 
Yukio Takeshida:387-827-1095:13 Uno Lane, Ashville, NC 23556:7/1/29:57000 
Vinh Tranh:438-910-7449:8235 Maple Street, Wilmington, VM 29085:9/23/63:68900 

1.把Jon的名字改爲Jonathan. 
2.刪除頭三行 
3.顯示5-10行 
4.刪除包含Lane的行. 
5.顯示全部生日在November-December之間的行 
6.把三個星號(***)添加到以Fred開頭的行 
7.用JOSE HAS RETIRED取代包含Jose的行 
8.把Popeye的生日改爲11/14/46 
9.刪除全部空白行 
10.寫一個腳本,將: 
.在第一行以前插入標題PERSONNEL FILE. 
.刪除以500結尾的工資 
.顯示文件內容,把姓和名顛倒 
.在文件末尾添加THE END 

1.sed 's/Jon/Jonathan/g' datafile 
2.sed '1,3d' datafile 
3.sed -n '5,10p' datafile 
4.sed '/Lane/d' datafile 
5.sed -ne '/[1-9]\{5\}:1[12]/p' datafile 
6.sed 's/^Fred/***&/' datafile 
7. sed -e 's/.*Jose.*/JOSE HAS RETIRE/g' datafile 
8.sed -n '/^Popeye/p' datafile |sed 's/[0-9]\{1,\}\/[0-9]\{1,\}\/[0-9]\{1,\}/11\/14\/46/' 
9.sed '/^$/d' datafile 
10. 
不太會,^_^
 

三.awk命令大練習 
文件: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 

上面的數據庫中包含名字,電話號碼和過去三個月裏的捐款 
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.awk -F : '{print $2}' datafile  2.awk -F: '/^Dan/{print $2}' datafile  3.awk -F: '/^Susan/{print $1 ,$2}' datafile  4.awk -F: '{print $1}' datafile |awk '{print $2}' |awk '/^D/'  5.awk -F: '{print $1}' datafile |awk '{print $1}' |awk '/^[CE]/'  6.awk -F: '{print $1}' datafile |awk '{if(length($1) == 4)print $1}'  7.awk -F: '/\[916\]/{print $1}' datafile  8.awk -F: '/^Mike/{print "$"$3"$"$4"$"$5}' datafile  9.awk -F: '{print $1}' datafile|awk '{print $2,",",$1}'  #!/bin/awk -f  BEGIN{  FS=":"}  {if($1 ~/ Savage/) print $1":"$2}  {if($1 ~/^Chet /) print "$"$3" [點擊圖片可在新窗口打開] "$4" [點擊圖片可在新窗口打開] "$5}  {if($3 == 250) print $1}#這個是抄別人的,以上的也有參照別人的.
相關文章
相關標籤/搜索