LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 44243|回复: 64

grep,sed,awk命令实例大练习[整理]

[复制链接]
发表于 2003-2-9 13:49:35 | 显示全部楼层 |阅读模式
本命令涵盖了grep的用法,感兴趣的兄弟们可以练练手;)(作业?)
关于sed和awk的练习题陆续推出
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:23400Norma 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:22350Jose 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对大小写不敏感.
 楼主| 发表于 2003-2-9 18:23:25 | 显示全部楼层
别的都会,就是第七道题有些绕得慌;)
不知道兄弟们做得如何?
发表于 2003-2-9 21:21:42 | 显示全部楼层
第七道题应该没有匹配才对。在题目中的冒号后面没空格,都是数字。
发表于 2003-2-10 12:05:20 | 显示全部楼层
我来学习一下:

1 cat datafile | grep San
2 cat datafile | grep ^J
3 cat datafile | grep 700$
4 cat datafile | grep -v 834
5 cat datafile | grep [:::]12[:/:]
6 不太明白意思
7 cat datafile | grep [A-Z][a-z][a-z][a-z][a-z][:::][[:space:]][A-Z]
8 cat datafile | grep -i [a-z][[:blank:]]k
9 cat datafile | grep -n ([1-9][0-9][0-9][0-9][0-9][0-9])$
10 cat datafile | egrep -i "Lincoln|lincoln"
 楼主| 发表于 2003-2-10 15:49:46 | 显示全部楼层
5.javalee//home/javalee/x:grep '\(:\)\(12\)\/' datafile
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

6.javalee//home/javalee/x:cut -f2 -d: datafile | grep ^498 #false,没有那个区号

8.javalee//home/javalee/x>grep -i '[a-z][ ]k' datafile

9.javalee//home/javalee/x>grep -n '[0-9][0-9][0-9][0-9][0-9][0-9]$' datafile

10.javalee//home/javalee/x>grep -i '[L|l]incoln' datafile
 楼主| 发表于 2003-2-10 17:19:55 | 显示全部楼层

sed命令大练习

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's的名字改成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
发表于 2003-2-12 10:58:39 | 显示全部楼层
1 sed -e 's/Jon/Jonathan/ datafile
2 sed -e '1,3d' datafile
3 sed -n '5,10p' datafile
4 sed -e '/Lane/d' datafile
5 sed -n '/[:::]1[1-2][:/:]/p' datafile
6 sed -e 's/^Fred/***Fred/' datafile
7 sed -e 's/^Jose.*/JOSE HAS RETIRE/g' datafile
8 cat datafile | grep Popeye | sed -e 's/3\/19\/35/11\/14\/46/'
9 sed -e '/^$/d' datafile
10 不会
 楼主| 发表于 2003-2-12 16:51:56 | 显示全部楼层
创建sed脚本步骤:
1,建立一个脚本
如:
  1. avalee//home/javalee/x>cat sedfile
  2. #this is sedfile
  3. 1i\
  4. this is example
  5. $ a\
  6. end
复制代码
2.用sed -f 执行sedfile脚本
  1. javalee//home/javalee/x>sed -f sedfile datafile
  2. this is example
  3. Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300
  4. ....
  5. Vinh Tranh:438-910-7449:8235 Maple Street, Wilmington, VM 29085:9/23/63:68900
  6. end
复制代码
发表于 2003-2-12 18:14:13 | 显示全部楼层
第8个好象不对,不过我也不会,用比较笨的方式实现:
sed -e '/Popeye/s/:.\/.*\/.*:/:11\/14\/46:/' datafile
sed -e '/Popeye/s/:..\/.*\/.*:/:11\/14\/46:/' datafile
那个月份的一位和两位不知道怎么匹配比较好。
 楼主| 发表于 2003-2-12 22:25:34 | 显示全部楼层
第八行artou写的没错,
  1. javalee//home/javalee/x>sed -n 's/3\/19\/35/11\/14\/46/p' datafile| grep ^P
  2. Popeye Sailor:156-454-3322:945 Bluto Street, Anywhere, USA 29358:11/14/46:22350
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表