linux之grep命令

1 grep用法

grep [options] regex [file...]

2 grep参数

选项描述: -i 忽略大小写。不会区分大小写字符。也可用--ignore-case 来指定。 -v 不匹配。通常,grep 程序会打印包含匹配项的文本行。这个选项导致 grep 程序 只会不包含匹配项的文本行。也可用--invert-match 来指定。 -c 打印匹配的数量(或者是不匹配的数目,若指定了-v 选项),而不是文本行本身。 也可用--count 选项来指定。 -l 打印包含匹配项的文件名,而不是文本行本身,也可用--files-with-matches 选项来指定。 -L 相似于-l 选项,但是只是打印不包含匹配项的文件名。也可用--files-without-match 来指定。 -n 在每个匹配行之前打印出其位于文件中的相应行号。也可用--line-number 选项来指定。 -h 应用于多文件搜索,不输出文件名。也可用--no-filename 选项来指定。

3 正则表达式

正则表达式的元字符包括 ^ $ . [ ] { } - ? * + ( ) | \

3.1 任意字符.

$ cat /usr/share/dict/words> mywords.txt
$ grep Kell. mywords.txt
Keller
Kelley
Kelley's
Kelli
Kelli's
Kellie
Kellie's
Kellogg
Kelly

输出文件中包含'Kell'的文件。.为任意字符,所以合计5个字符,其中第五个字符为任意字符。

3.2 锚点

^ 起始点 $终止点

$ grep '^keyb' mywords.txt
keyboard
keyboard's
keyboarded
keyboarder
keyboarder's
keyboarders
keyboarding
keyboards
$ grep '^kid$' mywords.txt
kid

下面这个可以查找特定单词

$ grep '^.ite$' mywords.txt
bite
cite
kite
lite
mite
nite
rite
site

注意^$匹配空行,这个命令很有用,可以删除空行

3.3 中括号表达式和字符类

中括号表达式,能够指定 一个字符集合(包含在不加中括号的情况下会被解释为元字符的字符)来被匹配。

$ grep 'h[ae]lly' mywords.txt
Shelly
Shelly's
lethally

只要包含hally或helly即可匹配到。

3.4否定

正则表达式中的第一个字符是插入字符^,则剩余字符被看作是被排除的字符。

grep '[^kb]nike' words
moniker
moniker's
monikers

可见,得到的是包含‘nike’,但前面的字符是除‘k’和‘b’之外的任意字符。中括号内,^不是锚定作用了,是‘非’的意思。

3.5传统的字符区域

比如,想找出以字母abcdefg开头,ike结尾的单词

$ grep '^[a-i]ike' words
bike
bike's
biked
biker
biker's
bikers
bikes
dike
dike's
diked
dikes
hike
hike's
hiked
hiker
hiker's
hikers
hikes
$ grep '^[A-Ka-i]elly' words
Kelly
belly
belly's
bellyache
bellyache's
bellyached
bellyaches
bellyaching
bellybutton
bellybutton's
bellybuttons
bellyful
bellyful's
bellyfuls
bellying

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券