1.grep [选项][模式][文件…]
grep命令由选项、模式和文件三部分组成,它在一个或多个文件中搜索满足模式的文本行,模板后的所有字符串被看做文件名,文件名可以有多个,搜索的结果被打印到屏幕,不影响原文件的内容。grep命令的选项用于对搜索过程进行补充说明,
//编译 7.txt 文件内容 YY结束
cat >>7.txt<< YY
编译完成 ctrl + c保存 wq退出
nl 7.txt //nl 用行号显示文本
grep‘xxxxxx’ -A 2 7.txt
//显示此文本的后两行内容
//显示此行内容
grep -n ‘the’ 7.txt
//-n :显示行数 查找the用行数显示出来
grep -vn
-vn //-vn: 是显示不带 the 用行数显示
-in //-i: 显示忽略大小写 有就显示
grep -n ‘t[ae]st’ 7.txt
// [] 第一位 tast 也行 test也行 行数显示
grep -n ‘0’ 7.txt
‘[^g]00’
//只要不是g开头其他都显示
‘[^a-z]xx’ //只要不是小写字母
grep -n ‘^the’ 7.txt
//以the开头内容 the 不能有其他内容
‘.$’ //显示内容最后一位是点的内容
tail -6 7.txt | head -5
//先取后6行内容head取前5行内容显示
‘g…d’ //起头g 结束d中间4个字符显示
‘[ot]’ ‘g.*g’ //两个g前后呼应
grep ‘g\w[2]g’ 7.txt
//正则表达式中的
?+{} 需要加入\才能起作用 //如果不加就直接起作用
注意:经过测试\d 不能使用想使用数字用[0-9]还有要使用正则表达式的?+{}前边要加斜杠
下面还有一些有意思的命令行参数:
grep -i pattern files :不区分大小写地搜索。默认情况区分大小写,
grep -l pattern files :只列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配’magic’,而不是’magical’),
grep -C number pattern files :匹配的上下文分别显示[number]行,
grep pattern1 | pattern2 files :显示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :显示既匹配 pattern1 又匹配 pattern2 的行。
grep -n pattern files 即可显示行号信息
grep -c pattern files 即可查找总行数
这里还有些用于搜索的特殊符号:
< 和 > 分别标注单词的开始与结尾。
例如:
grep man * 会匹配 ‘Batman’、’manic’、’man’等,
grep ‘<man’ * 匹配’manic’和’man’,但不是’Batman’,
grep ‘<man>’ 只匹配’man’,而不是’Batman’或’manic’等其他的字符串。
‘^’:指匹配的字符串在行首,
‘$’:指匹配的字符串在行 尾,
sed指令
sed ‘2,5d’
// 用行号显示 删除2-5行内容
nl 7.txt | sed ‘2,5d’ //不是真正的删除
//不删除原本文件内容
sed ‘2,5d’ 7.txt > 8.txt
//删除7.txt 2-5行内容 到新的8.txt文件里
显示被删除的样子
sed ‘/^#.*/d’ /etc/inttab | sed ‘/^$/d’
//删除注释加空白行
nl /etc/passwd | sed '2a ‘tttxxx’
//在第2行后面加
‘2i tttxxx’
//在前面加
‘2i ttt/iii/aaa’
插入3行内容
sed删除指令
//test.txt 内容如下
11 aa
22 bb
33 cc
23 dd
55 2e
sed ‘1,2d’ test.xx
输出:
33 cc
23 dd
55 2e
其中1,2d中的d表示删除,而d前面的表示删除的行的地址,而1,2表示一个地址范围,也就是删除第1行和第2行。地址范围的表示一般是 m,n 表示对m和n行之间的所有行进行操作,也包含第m行和第n行。sed的地址寻址中可以使用 表 示 最 后 一 行 , 例 如 m , 表示最后一行,例如 m, 表示最后一行,例如m, 表示对m行以及其后面的所有行进行操作,包括最后一样。m,$d就是删除m行以及其后面的所有行内容。当然我们还可以对某一行进行操作,例如2d表示仅仅删除第2行。除了使用数字范围 m,n 表示多行区间,以及m表示单行以外,我们还可以使用正则表达式选出符合条件的行,并对这些行进行操作,同样的是上面的文件:
sed ‘/2/d’ test.txt
输出:
11 aa
33 cc
上面的命令中 /2/ 是一个正则表达式,在sed中正则表达式是写在 /…/ 两个斜杠中间的,这个正则的意思是寻找所有包含2的行,执行相应的操作,也就是删除所有包含2的行,如果我们只想删除以2开头的行呢,只需要修改一下正则表达式就可以了:
sed ‘/^2/d’ test.txt
输出:
11 aa
33 cc
55 2e