一、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}#这个是抄别人的,以上的也有参照别人的.

转载于:https://blog.51cto.com/linuxjun/595774

grep awk sed练习相关推荐

  1. 五分钟入门文本处理三剑客grep awk sed

    点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达 今日推荐:Spring Boot + Vue 如此强大?竟然可以开发基于 C/S 架构的应用个人原创+1博客:点击前往,查 ...

  2. awk处理带有空格的字符串_五分钟入门文本处理三剑客grep awk sed

    介绍 grep awk sed是Linux下文本处理常用的命令,能完成很多神奇的操作,今天就分享一下这三个命令最常见的用法 grep 使用一般有如下两种形式 第一种形式 grep [option] [ ...

  3. cut\grep\awk\sed命令详解

    cut\grep\awk\sed命令详解 1.cut命令详解及实例 (1)作用:提取文件中指定的列 语法格式:cut  选项  文件名   (2)选项作用:      -d 分隔符     按照指定的 ...

  4. 利器 | 测试必会之 Linux 三剑客 ( grep / awk / sed )

    本文为霍格沃兹测试学院优秀学员课程学习系列笔记,想一起系统进阶的同学文末加群交流. Linux 给人的印象是黑乎乎的神秘窗口,文本操作和数据处理似乎没有 Windows 窗口界面直观方便.其实Linu ...

  5. grep awk sed 实例

    原文地址:http://blog.chinaunix.net/uid-16987232-id-3592539.html 文本过滤 5.1正则表达式 一种用来描述文本模式的特殊语法 由普通字符(例如字符 ...

  6. Linux文本处理命令:cut grep awk sed printf

    行 grep : 善于利用字符进行获取内容 针对于行的   [选项] [模式][文件]  选项规定内容样式 模式规定内容 sed:修改器   善于使用行数进行操作 针对于行的 列 cut :   cu ...

  7. linux相关(find/grep/awk/sed/rpm)

    如何查找特定的文件: find :在指定目录下查找文件 find -name "filename" :从当前目录查找文件 find / -name "filename&q ...

  8. Linux命令:grep awk sed详解

    1.grep grep [options] regex [file...] regex 是指一个正则表达式 -i : 忽略大小写.不会区分大小写字符.也可用–ignore-case 来指定. -v : ...

  9. awk,sed,grep基本用法列举

    点击下方链接了解awk,sed,grep awk,sed,grep 关注公众号,即可获得更多笔记哟

最新文章

  1. 滚动条——WPF ScrollViewer的应用
  2. python003 一 Python起步、pyhthon运行方式、语法结构、python变量
  3. DockPanel Suite 开源WINFORM 窗体停靠面板控件
  4. Python爬虫开发:post请求(用户登录)
  5. boost::mp11::mp_cond相关用法的测试程序
  6. 在ubuntu用arm ds-5社区版配合linaro交叉编译工具开发android linux应用
  7. tableau 自定义省份_在Tableau中使用自定义图像映射
  8. css hover变成手_web前端入门到实战:彻底掌握css动画「transition」
  9. Bone Collector【01背包】
  10. pandas 空字符串与na区别_关于python:Pandas用空白/空字符串替换NaN
  11. shell脚本执行时报bad interpreter: Text file busy的解决方法
  12. ubuntu从命令打开终端
  13. SOA(在Tuscany 中开发web service)
  14. 如何制作行政区划矢量图(shp格式)
  15. 使用insightface进行人脸识别批量下载图片
  16. 移动设备无线投屏到电视机
  17. 【微信小程序】粤语教学平台-粤言粤语
  18. 计算机达人成长之路目录
  19. moi3d 4.0中文版使用教程说明
  20. 解决Windows下移动硬盘无法弹出的问题:\$Extend\$RmMetadata\$TxfLog\$TxfLog.blf

热门文章

  1. python 屏幕找图 点击_捕获屏幕并查找参考图像
  2. Xamarin XAML语言教程隐藏文件使用Progress属性设置进度条
  3. 帆软报表调用mysql存储过程_FineReport单行与数据库交互的方法
  4. test1---peersim 0
  5. “纹身贴皮电路“:未来在皮肤上画个电路就能监测身体健康状况
  6. 漫威游戏的VR体验 让你尖叫
  7. 马斯克语出惊人:大部分人没必要活那么长,未来把意识注入机器人实现永生...
  8. OpenAI逆炼以文生图:参数缩水2/3性能却更强,还get局部编辑新技能|可试玩
  9. 给我10张画,我能还你1万张|Adobe团队搞定小样本图像生成
  10. 马斯克豁出4300员工,参与新冠研究,论文登上Nature子刊