linux查找内容命令

作者&投稿:申扶 (若有异议请与网页底部的电邮联系)
linux 查找文件内容命令~

Linux查找文件内容的常用命令方法。
从文件内容查找匹配指定字符串的行:

$ grep "被查找的字符串" 文件名
例子:在当前目录里第一级文件夹中寻找包含指定字符串的.in文件
grep "thermcontact" */*.in

从文件内容查找与正则表达式匹配的行:
$ grep –e “正则表达式” 文件名

查找时不区分大小写:
$ grep –i "被查找的字符串" 文件名

查找匹配的行数:
$ grep -c "被查找的字符串" 文件名


从文件内容查找不匹配指定字符串的行:
$ grep –v "被查找的字符串" 文件名

学习更多linux知识《Linux就该这么学》,从根目录开始查找所有扩展名为.log的文本文件,并找出包含”ERROR”的行
find / -type f -name "*.log" | xargs grep "ERROR"
例子:从当前目录开始查找所有扩展名为.in的文本文件,并找出包含”thermcontact”的行
find . -name "*.in" | xargs grep "thermcontact"

搜索、查找文件当中的内容,一般最常用的是grep命令,另外还有egrep, vi命令也能搜索文件里面内容

1:搜索某个文件里面是否包含字符串,使用grep "search content" filename1, 例如

$ grep ORA alert_gsp.log
$ grep "ORA" alert_gsp.log

例如我们需要搜索、查找utlspadv.sql文件中包含ORA的字符内容
[oracle@DB-Server admin]$ grep "ORA" utlspadv.sql-- ORA-XXXXX: Monitoring already started. If for example you want-- ORA-20111:-- ORA-20112:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'-- 0 | =>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM 0 0 2 99.3% 0% 0.7% ""-- | DBS1.REGRESS.RDBMS.DEV.US.ORACLE.COM=> 100% 0% 0% "" | ...-- =>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM 92 7 99.3% 0% 0.7% "" | ...-- | CAPTURE_USER1=>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM 2 0 0 0.E+00-- | CAPTURE_USER1=>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM-- ORA-20111:-- ORA-20112:-- ORA-20100:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'[oracle@DB-Server admin]$

如上所示,这个是一个模糊匹配,其实我是想要查看ORA这类错误,那么我要过滤掉哪一些没有用的,搜索的内容修改一下即可(当然也可以使用特殊参数,后面有讲述),如下所示。
[oracle@DB-Server admin]$ grep "ORA-" utlspadv.sql-- ORA-XXXXX: Monitoring already started. If for example you want-- ORA-20111:-- ORA-20112:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'-- ORA-20111:-- ORA-20112:-- ORA-20100:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'[oracle@DB-Server admin]$



2: 如果你想搜索多个文件是否包含某个字符串,可以使用下面方式

grep "search content" filename1 filename2.... filenamen
grep "search content" *.sql
例如我想查看当前目录下,哪些sql脚本包含视图v$temp_space_header(注意:搜索的内容如果包含特殊字符时,必须进行转义处理,如下所示)

[oracle@DB-Server admin]$ grep "v\$temp_space_header" *.sqlcatspacd.sql:drop public synonym v$temp_space_header;catspacd.sql:drop public synonym gv$temp_space_header;catspace.sql:create or replace view v_$temp_space_header as select * from v$temp_space_header;catspace.sql:create or replace public synonym v$temp_space_header for v_$temp_space_header;catspace.sql:create or replace view gv_$temp_space_header as select * from gv$temp_space_header;catspace.sql:create or replace public synonym gv$temp_space_headercatspace.sql: FROM gv$temp_space_header[oracle@DB-Server admin]$



3:如果需要显示搜索文本在文件中的行数,可以使用参数-n
[oracle@DB-Server admin]$ grep -n "v\$temp_space_header" *.sqlcatspacd.sql:68:drop public synonym v$temp_space_header;catspacd.sql:71:drop public synonym gv$temp_space_header;catspace.sql:1952:create or replace view v_$temp_space_header as select * from v$temp_space_header;catspace.sql:1953:create or replace public synonym v$temp_space_header for v_$temp_space_header;catspace.sql:1956:create or replace view gv_$temp_space_header as select * from gv$temp_space_header;catspace.sql:1957:create or replace public synonym gv$temp_space_headercatspace.sql:2357: FROM gv$temp_space_header[oracle@DB-Server admin]$


4: 如果搜索时需要忽略大小写问题,可以使用参数-i
[oracle@DB-Server admin]$ grep "V\$TEMP_SPACE_HEADER" *.sql[oracle@DB-Server admin]$ grep -i "V\$TEMP_SPACE_HEADER" *.sqlcatspacd.sql:drop public synonym v$temp_space_header;catspacd.sql:drop public synonym gv$temp_space_header;catspace.sql:create or replace view v_$temp_space_header as select * from v$temp_space_header;catspace.sql:create or replace public synonym v$temp_space_header for v_$temp_space_header;catspace.sql:create or replace view gv_$temp_space_header as select * from gv$temp_space_header;catspace.sql:create or replace public synonym gv$temp_space_headercatspace.sql: FROM gv$temp_space_header[oracle@DB-Server admin]$
另外,例如检查安装的MySQL组件
[root@DB-Server init.d]# rpm -qa | grep -i mysqlMySQL-devel-5.6.23-1.linux_glibc2.5MySQL-client-5.6.23-1.linux_glibc2.5MySQL-server-5.6.23-1.linux_glibc2.5


5:从文件内容查找不匹配指定字符串的行:

$ grep –v "被查找的字符串" 文件名
例如查找某些进程时,我们不想显示包含命令grep ora_mmon的进程,如下所示
[oracle@DB-Server admin]$ ps -ef | grep ora_mmon oracle 16675 16220 0 00:09 pts/1 00:00:00 grep ora_mmonoracle 21412 1 0 Aug22 ? 00:00:07 ora_mmon_gsp[oracle@DB-Server admin]$ ps -ef | grep ora_mmon | grep -v greporacle 21412 1 0 Aug22 ? 00:00:07 ora_mmon_gsp[oracle@DB-Server admin]$

6:搜索、查找匹配的行数:

$ grep -c "被查找的字符串" 文件名
[oracle@DB-Server admin]$ [oracle@DB-Server admin]$ grep "v\$temp_space_header" *.sqlcatspacd.sql:drop public synonym v$temp_space_header;catspacd.sql:drop public synonym gv$temp_space_header;catspace.sql:create or replace view v_$temp_space_header as select * from v$temp_space_header;catspace.sql:create or replace public synonym v$temp_space_header for v_$temp_space_header;catspace.sql:create or replace view gv_$temp_space_header as select * from gv$temp_space_header;catspace.sql:create or replace public synonym gv$temp_space_headercatspace.sql: FROM gv$temp_space_header[oracle@DB-Server admin]$ grep -c "v\$temp_space_header" catspacd.sql2[oracle@DB-Server admin]$ grep -c "v\$temp_space_header" catspace.sql5[oracle@DB-Server admin]$



7:有些场景,我们并不知道文件类型、或那些文件包含有我们需要搜索的字符串,那么可以递归搜索某个目录以及子目录下的所有文件

[oracle@DB-Server ~]$ grep -r "v\$temp_space_header" /u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql:create or replace view v_$temp_space_header as select * from v$temp_space_header;
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql:create or replace public synonym v$temp_space_header for v_$temp_space_header;
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql:create or replace view gv_$temp_space_header as select * from gv$temp_space_header;
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql:create or replace public synonym gv$temp_space_header
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql: FROM gv$temp_space_header
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspacd.sql:drop public synonym v$temp_space_header;
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspacd.sql:drop public synonym gv$temp_space_header;
[oracle@DB-Server ~]$

8:如果我们只想获取那些文件包含搜索的内容,那么可以使用下命令

[oracle@DB-Server ~]$ grep -H -r "v\$temp_space_header" /u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/ | cut -d: -f1
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspacd.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspacd.sql
[oracle@DB-Server ~]$ grep -H -r "v\$temp_space_header" /u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/ | cut -d: -f1 | uniq
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspace.sql
/u01/app/oracle/product/11.1.0/dbhome_1/rdbms/admin/catspacd.sql
[oracle@DB-Server ~]$

9:如果只想获取和整个搜索字符匹配的内容,那么可以使用参数w

你可以对比一下两者的区别
[oracle@DB-Server admin]$ grep -w "ORA" utlspadv.sql-- ORA-XXXXX: Monitoring already started. If for example you want-- ORA-20111:-- ORA-20112:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'-- ORA-20111:-- ORA-20112:-- ORA-20100:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'[oracle@DB-Server admin]$ grep "ORA" utlspadv.sql-- ORA-XXXXX: Monitoring already started. If for example you want-- ORA-20111:-- ORA-20112:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'-- 0 | =>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM 0 0 2 99.3% 0% 0.7% ""-- | DBS1.REGRESS.RDBMS.DEV.US.ORACLE.COM=> 100% 0% 0% "" | ...-- =>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM 92 7 99.3% 0% 0.7% "" | ...-- | CAPTURE_USER1=>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM 2 0 0 0.E+00-- | CAPTURE_USER1=>DBS2.REGRESS.RDBMS.DEV.US.ORACLE.COM-- ORA-20111:-- ORA-20112:-- ORA-20100:-- ORA-20113: 'no active monitoring job found'-- ORA-20113: 'no active monitoring job found'[oracle@DB-Server admin]$

10: grep命令结合find命令搜索
[oracle@DB-Server admin]$ find . -name '*.sql' -exec grep -i 'v\$temp_space_header' {} \; -printcreate or replace view v_$temp_space_header as select * from v$temp_space_header;create or replace public synonym v$temp_space_header for v_$temp_space_header;create or replace view gv_$temp_space_header as select * from gv$temp_space_header;create or replace public synonym gv$temp_space_headerFROM gv$temp_space_header./catspace.sqldrop public synonym v$temp_space_header;drop public synonym gv$temp_space_header;./catspacd.sql[oracle@DB-Server admin]$


11: egrep -w -R 'word1|word2' ~/klbtmp

12: vi命令其实也能搜索文件里面的内容,只不过没有grep命令功能那么方便、强大。

find,用于在文件树中查找文件并作相应的处理

-name:按照文件名查找文件

-perm:按照文件权限查找文件

-user:按照文件属主来查找文件

-size:按照指定的文件大小查找文件【+n:大于,-n:小于,n:等于】

-group:按照文件所属的组来查找文件

-mtime<-n><+n>:按照文件更改时间来查找文件,-n表示n天之内,+n表示n天以前

-newer file1 file2:查找更改时间在file1和file2之间的文件

例如:

  • find -mtime -2:查找48小时修改过的文件

  • find -name ".log":查找当前目录以".log"结尾的文件

  • find /opt/soft/test -perm 777:查找指定目录下权限为777的文件

  • find -type f -name "*.log":查找当前目录下以".log"结尾的普通文件

  • find -type d | sort:查找当前所有目标目录并排序

  • find /home/wansw -size +20M:查找大于20M的文件

  • locate指令,可以快速定位文件路径,利用事先建立的系统中的所有文件名称和路径的locate数据库,无需遍历整个文件系统,查询速度较快,为了保证查询准确性,需要定期更新。《Linux就该这么学》

  • updatedb:第一次运行前,创建locate数据库

  • grep,用于过滤/搜索指定字符串。可以使用正则表达式,能配合多种命令使用。

    用法:grep 【选项】 查找内容 源文件

    -A:显示符合的行及之后的内容

    -B:显示符合的行及之前的内容

    -C:显示符合的行及前后的内容

    -c:计算符合的行数目

    -n:显示匹配行和行号

    -i:忽略大小写

    规则表达式

    :'grep'表示匹配所有以grep开头的行

    '表示匹配所有以grep结尾的行

    .:'gr.p'表示匹配'gr'后面接任意字符然后是'p'

    :'grep'表示匹配一个或多个空格后紧跟grep的行

    []:[Gg]rep表示匹配Grep与grep

    []:[A-FH-Z]rep表示匹配不以A-F、H-Z开头并紧跟rep的行

    例如(grep命令大多数时候多要和别的命令一起使用才有意义):

    ps -ef | grep -c SVN:查找指定的进程的个数

    cat test.txt | grep -f test2.txt:从text2.txt中读取关键字后在test.txt中搜索

    cat test.txt | grep nf text2.txt:从text2.txt中读取关键字后在text.txt中搜索并显示行号

    grep 'linux' text.txt test2.txt:从多个文件中搜索关键字'linux'

    cat test.txt | grep -E 'ed|at':显示包含ed或at的行



linux文件查找内容linux文件查找内容
答:2、查找时使用正则表达式,匹配符合的字符串 grep-e“正则表达式”文件名 3、查找不匹配指定字符串的行:grep-v“被查找的字符串”文件名 4、查找时显示被查找字符串所在的行数 grep-n“查找的字符串”文件名 请教linux命令,我要查找当前目录下所有文件(包括子目录中的文件)内容包含test字符串的...

linux 查找文件命令
答:linux查找文件命令的方式:1、find。find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件。2、locate。locate命令其实是"find-name"的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库,这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且...

linux文本查找关键字命令linux文本查找
答:2.find命令,find本身就是查找命令,可以递归查找一个目录的子目录,所以用它是自然的。3.du命令,可以查看磁盘空间的使用情况,自然也可以用来查看磁盘上占用空间较多的文件 linux怎样打开文本文件?通过命令+文件名查看内容。如下命令可以查看。1,cat:由第一行开始显示文件内容;2,tac:从最后一行开始显示...

详解Linux中查找目录和文件的find和locate命令
答:说一下exec,-exec find命令对匹配的文件执行该参数所给出的其他linux命令。相应命令的形式为' 命令 - and' {} ;,注意{ }和;之间的空格。-ok 和- exec的作用相同,只不过和会人交互而已,OK执行前会向你确认是不是要执行。find命令主要参数:-name 按照文件名查找文件。-perm 按照文件权限来...

linux命令查看文件内容linux命令查看
答:系统不能自动启动该接口服务,这时需要手动创建网口服务:ifconfighme0plumb Linux查看ip即可以为接口le0创建网口服务 相应地,用ifconfig带unplumb参数可以停止服务并关闭网络。netconfig用来设置IP地址 编辑特别推荐:Linux命令之apt命令详解 使用epoll实现客户端UDP并发 文件操作——利用Linux系统调用。

linux查找内容命令
答:updatedb:第一次运行前,创建locate数据库 grep,用于过滤/搜索指定字符串。可以使用正则表达式,能配合多种命令使用。用法:grep 【选项】 查找内容 源文件 -A:显示符合的行及之后的内容 -B:显示符合的行及之前的内容 -C:显示符合的行及前后的内容 -c:计算符合的行数目 -n:显示匹配行和行号 ...

linux下查找文件的命令
答:2、在文件资料中查找文件:locate 3、搜索命令所在的目录及别名信息:which 4、搜索命令所在的目录及帮助文档路径:whereis 5、在文件中搜寻字符串匹配的行并输出:grep 6、分页显示一个文件或任何输出结果:more 7、分页显示一个文件并且可以回头:less 8、指定显示前多少行文件内容:head 9、指定显示...

linux 常用命令大全?
答:cat snow.txt 该命令显示文件snow.txt的内容,ctrl D退出cat。 5、 grep命令 grep命令的最大功能是在一堆文件中查找一个特定的字符串。 grep money test.txt 以上命令在test.txt中查找money这个字符串,grep查找是区分大小写的。 6 、touch命令 touch命令用来创建新文件,他可以创...

linux下查找文件内容
答:一.find命令 基本格式:find path expression 1.按照文件名查找 (1)find / -name httpd.conf#在根目录下查找文件httpd.conf,表示在整个硬盘查找 (2)find /etc -name httpd.conf#在/etc目录下文件httpd.conf (3)find /etc -name '*srm*'#使用通配符*(0或者任意多个)。表示在/etc目录下查找...

linux查看路径文件夹里的内容linux查看路径文件
答:很高兴本问题,此观点仅供参考!如有纰漏请尽情斧正!Linux下使用find命令查找文件或者文件夹:查找文件:find/(查找范围)-name查找关键字-typed。查找文件夹:find/(查找范围)-name查找关键字-print。另外find命令也可以通过正则表达式来进行查找。linux切换路径使用哪个命令?切换路径命令:用法:1、cd...