Shell學習:grep, sed, awk命令的練習題

來源:互聯網
上載者:User

標籤:

檔案: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

一、grep命令練習
1. 顯示所有包含San的行
grep San datafile
2.顯示所有以J開始的人名所在的行
grep "^J" datafile
3.顯示所有以700結尾的行
grep "700$" datafile
4.顯示所有不包括834的行
grep -v "834" datafile
5.顯示所有生日在December的行
grep [:::]12[:/:] datafile 或者 grep ‘\:12\/‘datafile
6.顯示所有電話號碼的區號為498的行
grep ‘\:486\‘ datafile
7.顯示所有這樣的行:它包含一個大寫字母,後跟四個小寫字母,一個冒號,一個空格,和一個大寫字母
grep [A-Z][a-z][a-z][a-z][a-z][:::][[:space:]][A-Z] datafile
8.顯示姓以K或k開頭的行
grep -i [a-z][[:blank:]]k datafile
9.顯示工資為六位元的行,並在前面加行號
grep -n ‘([1-9]\{6,\}$‘
10.顯示包括Lincoln或lincoln的行,並且grep對大小寫不敏感.
grep -i ‘lincoln‘ datafile
二.sed命令大練習
1.把Jon的名字改成Jonathan.
sed -e ‘s/Jon/Jonathan/ datafile
2.刪除頭三行
sed -e ‘1,3d‘ datafile
3.顯示5-10行
sed -n ‘5,10p‘ datafile
4.刪除包含Lane的行.
sed -e ‘/Lane/d‘ datafile
5.顯示所有生日在November-December之間的行
sed -n ‘/[:::]1[1-2][:/:]/p‘ datafile
6.把三個星號(***)添加到以Fred開頭的行
sed -e ‘s/^Fred/***Fred/‘ datafile
7.用JOSE HAS RETIRED取代包含Jose的行
sed -e ‘s/^Jose.*/JOSE HAS RETIRE/g‘ datafile
8.把Popeye的生日改成11/14/46
cat datafile | grep Popeye | sed -e ‘s/3\/19\/35/11\/14\/46/‘
9.刪除所有空白行
sed -e ‘/^$/d‘ datafile
10.寫一個指令碼,將:
.在第一行之前插入標題PERSONNEL FILE.
.刪除以500結尾的工資
.顯示檔案內容,把姓和名顛倒
.在檔案末尾添加THE END

建立sed指令碼步驟:
1,建立一個指令碼
如:

代碼:
avalee//home/javalee/x>cat sedfile#this is sedfile1ithis is example$ aend


2.用sed -f 執行sedfile指令碼

代碼:
javalee//home/javalee/x>sed -f sedfile datafilethis is exampleSteve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300....Vinh Tranh:438-910-7449:8235 Maple Street, Wilmington, VM 29085:9/23/63:68900end


三.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.顯示所有電話號碼
awk -F ":" ‘{print $2}‘ datafile
2.顯示Dan的電話號碼
awk -F ":" ‘/^Dan/{print $2}‘ datafile
3.顯示Susan的名字和電話號碼
awk -F ":" ‘/^Susan/{print $1,$2}‘ datafile
4.顯示所有以D開頭的姓
awk -F ":" ‘{print $1}‘ datafile | awk ‘{print $2}‘|awk ‘/^D/‘
5.顯示所有以一個C或E開頭的名
awk -F ":" ‘{print $1}‘ datafile | awk ‘{print $1}‘|awk ‘/^[CE]/‘
6.顯示所有只有四個字元的名
awk -F ":" ‘{print $1}‘ datafile | awk ‘{if(length($1)==4)print $1}‘ 
7.顯示所有區號為916的人名
awk -F ":" ‘/\[916\]/{print $1}‘ datafile
8.顯示Mike的捐款.顯示每個值時都有以$開頭.如$250$100$175
awk -F ":" ‘/^Mike/{print "$"$3"$"$4"$"$5}‘ datafile
9.顯示姓,其後跟一個逗號和名,如Jody,Savage
awk -F ":" ‘{print $1}‘ datafile | awk ‘{print $2,",",$1}‘
10.寫一個awk的指令碼,它的作用:
.顯示Savage的全名和電話號碼
.顯示Chet的捐款
.顯示所有頭一個月捐款$250的人名.
注:區號本來是圓括弧表示的。
指令碼如下:
#!/bing/awk -f
BEGIN{FS=":"}
{if($1 ~/Savage/) print $1":"$2}
{if($1}~/^Chet/) print "$"$3":$"$4":$"$5}
{if($3==250) print $1}
11.寫一個awk指令碼,它的作用
. 輸出所有人的的捐款總數
. 輸出12個人的捐款平均數
. 輸出單個季度捐款數最大值
. 輸出單個季度捐款數的最小值
指令碼如下:

BEGIN{
 FS=":";
 total = 0;
 average = 0;
}

{
 if(NR==1)
 {
  max = $3;
  min = $3;
 }

 total = $3 + $4 + $5;

 for(i=3; i<=NF; ++i)
 {
  if($i > max)
  {
   max = $i;
  }
 
  if($i < min)
  {
   min = $i;
  }
 }
}

END{
 average = total/12;
 printf("total = %d\n", total);
 printf("average = %d\n", average);
 printf("max = %d\n", max);
 printf("min = %d\n", min);
}

 

Shell學習:grep, sed, awk命令的練習題

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.