Linux之grep, sed, awk命令实例练习
今天看到的一个非常不错的练习,可以巩固一下,所学的shell脚本。
文件: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命令练习:
选项与参数:
-a :将 binary 文件以 text 文件的方式搜寻数据
-c :计算找到 ‘搜寻字符串’ 的次数
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 ‘搜寻字符串’ 内容的那一行!
–color=auto :可以将找到的关键词部分加上颜色的显示喔!
-A3 包含当前数据的后面三行数据,
-B2 包含当前数据的前两行
0.包含jon数据的前两行和后一行
grep -n -A1 -B2 ‘Jon’ test.log
1.显示所有包含San的行
grep –n ‘San’ datafile
2.显示所有以J开始的人名所在的行
grep –n ‘^J’ datafile
3.显示所有以700结尾的行
grep –n ‘700$’ datafile
4.显示所有不包括834的行
grep –vn ‘834’ datafile
5.显示所有生日在December的行
grep –n ‘:12/’ datafile
6.显示所有电话号码的区号为284的行
grep –n ‘:284-’ datafile
7.显示所有这样的行:它包含一个大写字母,后跟四个小写字母,一个冒号和一个数字
grep –n ‘[A-Z][a-z]/{4/}:[0-9]’ datafile
8.显示姓以K或k开头的行
grep –n ‘[a-z]/{1,/} [Kk]’ datafile
9.显示工资为六位数的行,并在前面加行号
grep –n ‘[0-9]/{6/}$’ datafile
10.显示包括Lincoln或lincoln的行,并且grep对大小写不敏感
grep –in ‘lincoln’ datafile
sed命令练习
sed,stream editor,一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换、删除、新增、选取等特定工作。
sed [options] ‘command’ 输入文本
options
-n 取消sed默认输出
-i 改变文件内容
-r 让sed命令支持扩展的正则表达式(默认是基础正则表达式)
p print打印 ; d delete 删除
①打印:
打印第2行的内容;打印第一行到第二行的内容。
sed -n ‘2p’ test.log
sed -n ‘1,2p’ test.log
处理的命令: p print打印 ; d delete 删除
②过滤: sed -n ‘/过滤的内容/处理的命令’ 文件
sed -n ‘/Jon/p’ test.log
③替换:sed -i ‘s#想要修改的内容#新内容#g’ 文件
sed -n ‘/Jon/p’ test.log
sed -i ‘s#Jon#Babmoo#g’ test.log
sed -n ‘/Babmoo/p’ test.log
s编辑替换;g全部替换。
s常说的查找并替换,用一个字符串替换成另一个。
g(global)与s联合使用时,表示对当前行全局替换。
“#”是分隔符,可以用/@等替换
④后向引用:sed -r ‘s#(可以用正则匹配)#\1#g’ 文件
前面小括号里的内容,能用后面的+数字(\1)取出来。即把前面正则匹配括号内的结果,在后面\1取出来操作。
1.把Jon的名字改成Babmoo
sed ‘s/Jon/Babmoo/g’ datafile
2.删除头三行
sed ‘1,3d’ datafile
3.显示5-10行
sed –n ‘5,10p’ datafile
4.删除包含Lane的行
sed ‘/Lane/d’ datafile
5.显示所有生日在November-December之间的行
sed ‘/:1[12]/p’ datafile
6.把三个星号(***)添加到也Fred开头的行
sed –e ‘s/Fred/***Fred’ datafile
7.用JOSE HAS RETIRED取代包含Jose的行
sed –e ‘s/.Jose./JOSE HAS RETIRED/g’ datafile
8.把Popeye的生日改成11/14/46
sed ‘/^Popeye/p’ datafile | sed ‘s/[0-9]/{1,/}//[0-9]/{1,/}//[0-9]/{1,/}/11//14//46/g’
9.删除所有空白行
sed ‘/^$/d’ datafile
文件: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
awk命令练习
awk [-F field-separator] 'commands’input-file(s)
commands是真正awk命令,[-F域分隔符],input-file(s)是待处理的文件。
在awk中,文件的每一行中,由域分隔符分开的每一项称为一个域。通常,不指明-F域分隔符的情况下,默认的域分隔符是空格。
awk ‘{print $1}’ 文件
$0打印一行内容,$1打印第一列, 2 打 印 第 二 列 , 2打印第二列, 2打印第二列,NF打印最后一列,$NF-1打印倒数第二列。
上面的数据库中包含名字,电话号码和过去三个月里的捐款
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 ‘/1/’
6.显示所有只有四个字符的名
awk –F : ‘{print $1}’ datafile | awk ‘{if(length($1) == 4) print $1}’
7.显示所有区号为916的人名
awk –F : ‘/[916]/{print $1}’ datafile
8.显示Mike的捐款.显示每个值时都有以$开头,如$250$100KaTeX parse error: Expected '}', got 'EOF' at end of input: …/^Mike/{print “” 3 ” 3” 3”” 4 ” 4” 4””$5}’ datafile
9.显示姓,其后跟一个逗号和名,如Jody,Savage
awk –F : ‘{print $1}’ datafile | awk ‘{print $2”,”$1}’
10.写一个awk的脚本,它的作用:
显示Savage的全名和电话号码
显示Chet的捐款
显示所有头一个月捐款$250的人名。
注:区号本来是圆括号表示的。
#!/bin/awk –f
BEGIN{FS=”:”}
{if($1 ~/Savage/) print $1”:”$2}
{if($1 ~/^Chet/) print “$”$3”$”$4”$”$5}
{if($3 == 250) print $1}
作者:monkey_d_meng
来源:CSDN
原文:https://blog.csdn.net/MONKEY_D_MENG/article/details/5924357
版权声明:本文为博主原创文章,转载请附上博文链接!
CE ↩︎