天天看点

linux如何搜全部文件含有字符串,Linux下查找目录中全部文件中含有某个字符串,而且只打印出文件名...

假设含有“hello”web

find .|xargs grep -ri "hello" -l

这个能够,我测试了简化的:grep -l "hello" *也行。

xargs正则表达式

grep的经常使用选项:grep [option] pattern fileshell

-V: 打印grep的版本号

-E: 解释PATTERN做为扩展正则表达式,也就至关于使用egrep。 或操做

-F : 解释PATTERN做为固定字符串的列表,由换行符分隔,其中任何一个都要匹配。也就至关于使用fgrep。

-G: 将范本样式视为普通的表示法来使用。这是默认值。加不加都是使用grep。

匹配控制选项:svg

-e : 使用PATTERN做为模式。这能够用于指定多个搜索模式,或保护以连字符( - )开头的图案。指定字符串作为查找文件内容的样式。

-f : 指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。

-i : 搜索时候忽略大小写

-v: 反转匹配,选择没有被匹配到的内容。

-w:匹配整词,精确地单词,单词的两边必须是非字符符号(即不能是字母数字或下划线)

-x:仅选择与整行彻底匹配的匹配项。精确匹配整行内容(包括行首行尾那些看不到的空格内容都要彻底匹配)

-y:此参数的效果和指定“-i”参数相同。

通常输出控制选项:工具

-c: 抑制正常输出;而是为每一个输入文件打印匹配线的计数。

--color [= WHEN]:让关键字高亮显示,如--color=auto

-L:列出文件内容不符合指定的范本样式的文件名称

-l : 列出文件内容符合指定的范本样式的文件名称。

-m num:当匹配内容的行数达到num行后,grep中止搜索,并输出中止前搜索到的匹配内容

-o: 只输出匹配的具体字符串,匹配行中其余内容不会输出

-q:安静模式,不会有任何输出内容,查找到匹配内容会返回0,未查找到匹配内容就返回非0

-s:不会输出查找过程当中出现的任何错误消息,-q和-s选项由于与其余系统的grep有兼容问题,shell脚本应该避免使用-q和-s,而且应该将标准和错误输出重定向到/dev/null 代替。

输出线前缀控制:性能

-b:输出每个匹配行(或匹配的字符串)时在其前附加上偏移量(从文件第一个字符到该匹配内容之间的字节数)

-H:在每个匹配行以前加上文件名一块儿输出(针对于查找单个文件),当查找多个文件时默认就会输出文件名

-h:禁止输出上的文件名的前缀。不管查找几个文件都不会在匹配内容前输出文件名

--label = LABEL:显示实际来自标准输入的输入做为来自文件LABEL的输入。这是特别在实现zgrep等工具时很是有用,例如gzip -cd foo.gz | grep --label = foo -H的东西。看到 也是-H选项。

-n:输出匹配内容的同时输出其所在行号。

-T:初始标签确保实际行内容的第一个字符位于制表位上,以便对齐标签看起来很正常。在匹配信息和其前的附加信息之间加入tab以使格式整齐。

上下文线控制选项:测试

-A num:匹配到搜索到的行以及该行下面的num行

-B num:匹配到搜索到的行以及该行上面的num行

-C num:匹配到搜索到的行以及上下各num行

文件和目录选择选项:code

-a: 处理二进制文件,就像它是文本;这至关于--binary-files = text选项。不忽略二进制的数据。

--binary-files = TYPE:若是文件的前几个字节指示文件包含二进制数据,则假定该文件为类型TYPE。默认状况下,TYPE是二进制的,grep一般输出一行消息二进制文件匹配,或者若是没有匹配则没有消息。若是TYPE不匹配,grep假定二进制文件不匹配;这至关于-I选项。若是TYPE是文本,则grep处理a二进制文件,若是它是文本;这至关于-a选项。警告:grep --binary-files = text可能会输出二进制的垃圾,若是输出是一个终端和若是可能有讨厌的反作用终端驱动程序将其中的一些解释为命令。

-D:若是输入文件是设备,FIFO或套接字,请使用ACTION处理。默认状况下,读取ACTION,这意味着设备被读取,就像它们是普通文件同样。若是跳过ACTION,设备为 默默地跳过。

-d: 若是输入文件是目录,请使用ACTION处理它。默认状况下,ACTION是读的,这意味着目录被读取,就像它们是普通文件同样。若是跳过ACTION,目录将静默跳过。若是ACTION是recurse,grep将递归读取每一个目录下的全部文件;这是至关于-r选项。

--exclude=GLOB:跳过基本名称与GLOB匹配的文件(使用通配符匹配)。文件名glob可使用*,?和[...]做为通配符,和\引用通配符或反斜杠字符。搜索其文件名和GLOB通配符相匹配的文件的内容来查找匹配使用方法:grep -H --exclude=c* "old" ./* c*是通配文件名的通配符./* 指定须要先通配文件名的文件的范围,必需要给*,否则就匹配不出内容,(若是不给*,带上-r选项也能够匹配)

--exclude-from = FILE:在文件中编写通配方案,grep将不会到匹配方案中文件名的文件去查找匹配内容

--exclude-dir = DIR:匹配一个目录下的不少内容同时还要让一些子目录不接受匹配,就使用此选项。

--include = GLOB:仅搜索其基本名称与GLOB匹配的文件(使用--exclude下所述的通配符匹配)。

-R ,-r :以递归方式读取每一个目录下的全部文件; 这至关于-d recurse选项。

其余选项:xml

--line-buffered: 在输出上使用行缓冲。这可能会致使性能损失。

--mmap:启用mmap系统调用代替read系统调用

-U:将文件视为二进制。

-z:将输入视为一组行,每一行由一个零字节(ASCII NUL字符)而不是a终止新队。与-Z或--null选项同样,此选项能够与排序-z等命令一块儿使用来处理任意文件名。