使用grep可以查找包含指定字符串的文件
格式:
grep “要查找的字符串” 文件名
例子:
grep "192.168.0.1" /etc
文件名可以使用基本正则表达式(BRE),例如, 查找test目录下的所有文件,是否包含www.tycode.com字符串。
grep “www.tycode.com” /root/zzh/test/*
几个常用的查询指令:
1、查找时不区分字符串的大小写
grep -i “查找的字符串” 文件名
2、查找时使用正则表达式,匹配符合的字符串
grep -e “正则表达式” 文件名
3、查找不匹配指定字符串的行:
grep -v “被查找的字符串” 文件名
4、查找时显示被查找字符串所在的行数
grep -n “查找的字符串” 文件名
Ⅱ linux下查找某个目录下所有文件中是否含有某个字符串
使用命令 grep 来查找
1:找到并显示内容 grep -R "要查询的字符" 文件夹名称
2:不显示内容只是找到包含字符的文件 grep -lR "要查询的字符" 文件夹名称
Ⅲ linux grep命令怎么用
grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。
grep的详细使用方法有很厚一本书,此处无法详细说明,只能列出grep常用用法
[root@www ~]# grep [-acinv] [--color=auto] '搜寻字符串' filename
选项与参数:
-a :将 binary 文件以 text 文件的方式搜寻数据
-c :计算找到 '搜寻字符串' 的次数
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!
--color=auto :可以将找到的关键词部分加上颜色的显示喔!
Ⅳ linux查找目录下的所有文件中是否含有某个字符串
grep -rn "要查找的字符串" *
-r 是递归查找
-n 是显示行号
*: 表示当前目录所有文件,也可以是某专个文件名。
grep命令属的常用格式为:grep [选项] ”模式“ [文件]。
模式部分:
1、直接输入要匹配的字符串,这个可以用fgrep(fast grep)代替来提高查找速度,比如我要匹配一下hello.c文件中printf的个数:fgrep -c "printf" hello.c。
2、使用基本正则表达式。
(4)greprn查找文件内容扩展阅读:
查找字符串的第二种方法:
find .|xargs grep “要查找的字符串”
find . -exec grep “要查找的字符串” {} ;
find / -name "要查找的字符串"
find / -name "要查找的字符串"
Ⅳ Linux如何对文件内容中的关键字进行查找
1、首先我们准备一个要查找的文件,如下图所示。
Ⅵ linux下批量查询文件内容字符串并替换
查找批量替换文件时,去除某种类型的文件,下面表示在./salt/*下的所有文件中,不包括tar.gz结尾的文件,搜索包含有node01字符串的文件
grep "node01" -rl ./salt/* --exclude=*.tar.gz
其实这里的 -r表示递归,-l表示输出文件名,
也可以将 -rl替换为-rn,-n表示是哪一行,会输出行号详细信息
grep "node01" -rn ./salt/* --exclude=*.tar.gz
替换字符串:
把./salt/*目前下所有文件进行遍历,查是否包含node01字符串的,不包括tar.gz结尾的文件。然后把node01用test01进行批量替换。
grep "node01" -rl ./salt/* --exclude=*.tar.gz | xargs sed -i 's/node01/test01/g'
Ⅶ grep命令
grep命令是一个强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
正则表达式是描述一组字符串的一个模式,正则表达式可以是一些纯文本文字,也可以是用来产生模式的一些特殊字符。
grep命令在每一个文件或特定输出中搜索特定的模式,当使用grep时,会输出跟指定模式匹配的每一行,但是使用grep命令并不改变文件中的内容。
如果发现某文件的内容符合所指定的范本样式,预设grep指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为-,则grep指令会从标准输入设备读取数据。
语法:grep [-abcEFGhHilLnqrsvVwxy][-A<显示行数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][--help][范本样式][文件或目录...]。
参数:
-a或--text :不要忽略二进制的数据。
-A<显示行数>或--after-context=<显示行数>:除了显示符合范本样式的那一列之外,并显示该行之后的内容。
-b或--byte-offset :在显示符合样式的那一行之前,标示出该行第一个字符的编号。
-B<显示行数>或--before-context=<显示行数>:除了显示符合样式的那一行之外,并显示该行之前的内容。
-c或--count :计算符合样式的列数。
-C<显示行数>或--context=<显示行数>或-<显示行数>:除了显示符合样式的那一行之外,并显示该行之前后的内容。
-d <动作>或--directories=<动作>:当指定要查找的是目录而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
-e<范本样式>或--regexp=<范本样式>:指定字符串做为查找文件内容的样式。
-E或--extended-regexp :将样式为延伸的正则表达式来使用。
-f<规则文件>或--file=<规则文件>:指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。
-F或--fixed-regexp :将样式视为固定字符串的列表。
-G或--basic-regexp :将样式视为普通的表示法来使用。
-h或--no-filename :在显示符合样式的那一行之前,不标示该行所属的文件名称。
-H或--with-filename :在显示符合样式的那一行之前,表示该行所属的文件名称。
-i或--ignore-case :忽略字符大小写的差别。
-l或--file-with-matches :列出文件内容符合指定的样式的文件名称。
-L或--files-without-match :列出文件内容不符合指定的样式的文件名称。
-n或--line-number :在显示符合样式的那一行之前,标示出该行的列数编号。
-o或--only-matching :只显示匹配PATTERN部分。
-q或--quiet或--silent :不显示任何信息。
-r或--recursive :此参数的效果和指定"-d recurse"参数相同。
-s或--no-messages :不显示错误信息。
-v或--invert-match :显示不包含匹配文本的所有行。
-V或--version :显示版本信息。
-w或--word-regexp :只显示全字符合的列。
-x --line-regexp :只显示全列符合的列。
-y :此参数的效果和指定"-i"参数相同。
Ⅷ linux用grep在文件中查找字符串并显示字符串在文件中的行号
如果你想在当前目录下 查找"hello,world!"字符串,可以这样:
grep -rn "hello,world!" ./
./ : 表示路径为当前目录.
-r 是递归查找
-n 是显示行号