linux下的文件查找命令对比(locate,find,grep,sed)

    在linux下,文件系统占据着非常重要的位置,而我们对于文件系统的操作也显得尤为重要。

如果我们想熟悉的操作文件系统,其中,我们需要对文本的查找,截取等命令需要熟悉的掌握。

这里就不得不说几个关于文本操作的几个命令的作用详细介绍和对比。比如: locate,find ,grep ,sed等。

这里,grep ,sed 都属于文本的查找,过滤的文本搜索工具。locate,find属于查找文件的的工具,可以查找我们想找却又

不知道具体路径的文件;或者只知道文件的部分信息,这样我们可以使用locate和find进行搜索文件。

1.locate  

locate 属于非实时查找(根据索引查找),其特点为,查找速度快,非精准查找,模糊查找。

首先,locate对于文件的搜索是根据数据库来搜索文件的,在数据库中搜索文件比使用find进行搜索的速度要快。

这个是比较简单的搜索工具,仅需要 locate + keyword ,使用locate命命令后面跟上需要搜索的关键词即可。

但是,有一点需要注意的就是因为locate是在数据库中进行搜索的,而我们都知道数据库更新需要一定条件,它

并不是随时更新的。所以我们使用locate进行搜索是很多时候需要先手动更新一下数据库。手动更新数据库的方法就是使

updatedb命令更新数据库,数据库由于信息量比较大,所以更新时一般会比较慢 。所以为了不影响我们的工作,我们可以

在updatedb 后面跟上一个 &符号,这样会在后台自动的更新数据库,我们也可以在终端上做别的工作。

例如,我们不知道 issue的位置,我们需要查一下:

locate.png

2.find 

find 属于实时查找(遍历所有的文件进行条件匹配),其特点为:精准查找,但速度比较慢

find的用法结构为:find [option]…[查找路径][查找条件][处理动作]

[查找路径]:默认为当前目录

[查找条件]:默认为指定路径下的所有文件

[处理动作]:默认为显示在屏幕上

查找条件:

-name "文件名称":支持使用glob通配符

* ? [] [^]

-iname "文件名称":查找时忽略字符的大小写

-user USERNAME :根据文件的属主进行查找

-group GRPNAME :根据文件的属组进行查找

-uid UID

-gid GID

-nouser:查找没有属主的文件

-nogroup:查找没有属组的文件

-inum n :按inode号进行查询

组合条件查找:

与 : -a ,同时满足

或 : -o ,满足一个条件即可

非 : !,-not ,条件取反

德·摩根定律:

非(P 且 Q) = (非 P) 或 (非 Q)

非(P 或 Q) = (非 P) 且 (非 Q)

!A -a !B = !(A -o B)

!A -o !B = !(A -a B)

根据文件类型进行查找:

-type TYPE :根据文件类型查找

f :普通文件 d :目录文件 l :符号链接 b :块设备

c :字符设备 s :套接字文件 p :命令管道

根据文件大小查询:

-size[+|-]#UNIT :常用单位 :k,M,G

#UNIT: (#-1, #],如:6k

-#UNIT:[0,#-1], 如:-6k

+#UNIT:(#,∞), 如:+6k

案例:1.找出/tmp目录下,属主不是root,且文件名不是fstab的文件  (为了显示摩根定律的作用,我使用 head -4 只取了前4行)

findtest1.png

 2。排除目录

  findtest2.png

3.sed流编译器

    说流编译器可能有点过于概念化,通俗的讲它的编译功能主要体现在 sed -i 这个参数上,通过修改原文本,它的作用和grep都是进行文本内容的操作,不是查找文件。这里偶然间看到一个关于sed的功能图,很详细。供参考!

sed快速学习.png

4.grep 

grep 是一个文本过滤器,过滤文本内容。按照模式的内容进行逐行匹配并打印下来。grep和sed都支持正则表达式。在对文本的搜索,过滤中,这两个文本处理工具是离不开正则表达式的。

    grep [OPTIONS] PATTERN [FILE…]

    [option] :

    –color=auto: 对匹配到的文本着色显示;  

    -v: 显示不能够被pattern匹配到的行;  

    -i: 忽略字符大小写  

    -n:显示匹配的行号  

    -c: 统计匹配的行数  

    -o: 仅显示匹配到的字符串;  

    -q: 静默模式,不输出任何信息  

    -A #:after, 后#行  

    -B #: before, 前#行  

    -C #:context, 前后各#行  

    -e:实现多个选项间的逻辑or关系
grep
–e ‘cat ’
-e ‘dog’ file
 

    –
w:整行匹配整个单词

    

    –
E:使用ERE

这个还是对练习练习,我在上一篇博客中有关于sed和grep与正则表达式的使用,具体的案例。

原创文章,作者:zhong,如若转载,请注明出处:http://www.178linux.com/34940

(1)
zhongzhong
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • 初识Linux基础

    一:计算机的组成及其基本功能 计算机主要由五大基础部件组成:控制器,运算器,存储器,输入设备,输出设备. 控制器:计算机的核心组件,协调各程序的运行,对计算机的各项资源进行控制分配; 运算器:计算机实现算术运算以及逻辑运算的部件; 存储器:计算机用来存放数据和程序的基本部件。 存储器由若干存储单元组成,每个存储单元都有一个地址,计算机通过地址对存储单元进行读…

    Linux干货 2018-03-04
  • linux再次入门

               时隔一年,重新拾起Linux,从头开始再学一遍            现在来总结一下曾经可能听说过但是我以前绝对不会的命令(尴尬脸) 克隆窗口:右键单击点克隆窗口(真是…

    2017-07-15
  • 第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 目录管理类命令: cd:变更目录   命令格式:cd [DIRECTORY] pwd:显示当前目录的绝对路径 ls:显示文件或目录内容     命令格式:ls [OPTION]… [FILE]… &…

    Linux干货 2017-01-08
  • Tomcat性能优化-2

    修改Connector运行模式 启用NIO 或 APR bio介绍 bio(blocking I/O,阻塞式I/O操作),表示Tomcat使用的是传统的Java I/O操作 默认模式,性能最差,没有经过任何优化处理和支持 nio模式 nio(non-blocking I/O),Java SE 1.4…

    Linux干货 2016-09-19
  • rsync+inotify 实现数据实时同步

        Rsync (Rmote sync)是一款非常好的数据同步工具,能够通过对比同步双方的数据变动,实现增量同步,还可以通过LAN/WAN实现远程多台主机间文件的同步,还能结合crond任务计划来执行自动备份,又可以结合ssh实现远程数据备份的安全,种种特性使他看起来相当优秀。但如果需备份数据十分庞大时,它的不足之处就显现出来了,比如…

    Linux干货 2015-07-24
  • 如何实现在命令行输入pwd时显示出ifconfig的效果

    1、使用type ifconfig 查看   2、使用type pwd 查看 如果还没有使用过pwd则显示如下,表示pwd属于内部命令,然后输入enable -n pwd 禁用这个内部命令   如果已经使用过,就会显示hash,已经缓存过   此时就不仅需要禁用内部命令,还需要使用hash -d pwd 清除pwd的缓存,使其在…

    2017-07-13

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-19 10:08

    对文件查找部分文字太多,能简练尽量简练点,多些操作和联系,find命令是比较常用的工具,需多加练习,熟练掌握。