find命令是一个无处不在命令,是linux中最有用的命令之一。find命令用于:在一个目录(及子目录)中搜索文件,你能够指定一些匹配条件,如按文件名、文件类型、用户甚至是时间戳查找文件。下面就经过实例来体验下find命令的强大。html
man文档中给出的find命令的通常形式为:linux
find [-H] [-L] [-P] [-D debugopts] [-Olevel] [path...] [expression]
其实[-H] [-L] [-P] [-D debugopts] [-Olevel]这几个选项并不经常使用,上面的find命令的经常使用形式能够简化为:find [path...] [expression]正则表达式
path:find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录
expression:expression能够分为——“-options [-print -exec -ok ...]”
[options]主要参数:
-c:只输出匹配行的计数。
-i:不区分大小写
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的全部行。
-options,指定find命令的经常使用选项,下节详细介绍 -print,find命令将匹配的文件输出到标准输出 -exec,find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } \;,注意{ }和\;之间的空格 find ./ -size 0 -exec rm {} \; 删除文件大小为零的文件 (还能够以这样作:rm -i `find ./ -size 0` 或 find ./ -size 0 | xargs rm -f &) 为了用ls -l命令列出所匹配到的文件,能够把ls -l命令放在find命令的-exec选项中:find . -type f -exec ls -l { } \; 在/logs目录中查找更改时间在5日之前的文件并删除它们:find /logs -type f -mtime +5 -exec rm { } \; -ok,和-exec的做用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每个命令以前,都会给出提示,让用户来肯定是否执行。 find . -name "*.conf" -mtime +5 -ok rm { } \; 在当前目录中查找全部文件名以.LOG结尾、更改时间在5日以上的文件,并删除它们,只不过在删除以前先给出提示
也有人这样总结find命令的结构:shell
find start_directory test
options
criteria_to_match
action_to_perform_on_results
-name : 按照文件名查找文件。express
// 在/dir目录及其子目录下面查找名字为filename的文件 $ find /dir -name filename // 在当前目录及其子目录(用“.”表示)中查找任何扩展名为“c”的文件 $ find . -name "*.c"
-perm:按照文件权限来查找文件。apache
// 在当前目录下查找文件权限位为755的文件,即文件属主能够读、写、执行,其余用户能够读、执行的文件 $ find . -perm 755 –print
-prune:使用这一选项可使find命令不在当前指定的目录中查找,若是同时使用-depth选项,那么-prune将被find命令忽略。安全
// 在/apps目录下查找文件,但不但愿在/apps/bin目录下查找 $ find /apps -path "/apps/bin" -prune -o –print // 在/usr/sam目录下查找不在dir1子目录以内的全部文件 $ find /usr/sam -path "/usr/sam/dir1" -prune -o –print
// 在$HOME目录中查找文件属主为sam的文件 $ find ~ -user sam –print
// 在/apps目录下查找属于gem用户组的文件 $ find /apps -group gem –print
// 在系统根目录下查找更改时间在5日之内的文件 $ find / -mtime -5 –print // 在/var/adm目录下查找更改时间在3日之前的文件 $ find /var/adm -mtime +3 –print
$ find / –nogroup -print
$ find /home -nouser –print
b - 块设备文件。 d - 目录。 c - 字符设备文件。 p - 管道文件。 l - 符号连接文件。 f - 普通文件。
$ find /etc -type d –print // 在/etc目录下查找全部的目录 $ find . ! -type d –print // 在当前目录下查找除目录之外的全部类型的文件 $ find /etc -type l –print // 在/etc目录下查找全部的符号连接文件
$ find . -size +1000000c –print // 在当前目录下查找文件长度大于 1M 字节的文件 $ find /home/apache -size 100c –print // 在/home/apache目录下查找文件长度刚好为100字节的文件 $ find . -size +10 –print // 在当前目录下查找长度超过10块的文件(一块等于512字节)
// 它将首先匹配全部的文件而后再进入子目录中查找 $find / -name "CON.FILE" -depth –print
// 从当前目录开始查找位于本文件系统中文件名以XC结尾的文件(不进入其余文件系统) $ find . -name "*.XC" -mount –print
在使用find命令的-exec选项处理匹配到的文件时, find命令将全部匹配到的文件一块儿传递给exec执行。但有些系统对可以传递给exec的命令长度有限制,这样在find命令运行几分钟以后,就会出现溢出错误。错误信息一般是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一块儿使用。app
find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是所有,不像-exec选项那样。这样它能够先处理最早获取的一部分文件,而后是下一批,并如此继续下去。工具
在有些系统中,使用-exec选项会为处理每个匹配到的文件而发起一个相应的进程,并不是将匹配到的文件所有做为参数一次执行;这样在有些状况下就会出现进程过多,系统性能降低的问题,于是效率不高;性能
而使用xargs命令则只有一个进程。另外,在使用xargs命令时,到底是一次获取全部的参数,仍是分批取得参数,以及每一次获取参数的数目都会根据该命令的选项及系统内核中相应的可调参数来肯定。
来看看xargs命令是如何同find命令一块儿使用的,并给出一些例子。
// 查找系统中的每个普通文件,而后使用xargs命令来测试它们分别属于哪类文件 $ find . -type f -print | xargs file // 在整个系统中查找内存信息转储文件(core dump) ,而后把结果保存到/tmp/core.log 文件中 $ find / -name "core" -print | xargs echo "" >/tmp/core.log // 用grep命令在全部的普通文件中搜索hostname这个词 $ find . -type f -print | xargs grep "hostname" // 删除3天之前的全部东西 (find . -ctime +3 -exec rm -rf {} \;) $ find ./ -mtime +3 -print|xargs rm -f –r // 删除文件大小为零的文件 $ find ./ -size 0 | xargs rm -f &
find命令配合使用exec和xargs可使用户对所匹配到的文件执行几乎全部的命令。
grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
grep命令用于搜索由Pattern参数指定的模式,并将每一个匹配的行写入标准输出中。这些模式是具备限定的正则表达式,它们使用ed或egrep命令样式。若是在File参数中指定了多个名称,grep命令将显示包含匹配行的文件的名称。
对 shell 有特殊含义的字符$, *, [, |, ^, (, ), \
出如今 Pattern参数中时必须带双引号。若是 Pattern参数不是简单字符串,一般必须用单引号将整个模式括起来。在诸如 [a-z]
, 之类的表达式中,-
(减号)可根据当前正在整理的序列来指定一个范围。整理序列能够定义等价的类以供在字符范围中使用。若是未指定任何文件,grep会假定为标准输入。
$ ls -l | grep '^a' // 经过管道过滤ls -l输出的内容,只显示以a开头的行。 $ grep 'test' d* // 显示全部以d开头的文件中包含test的行。 $ grep 'test' aa bb cc // 显示在aa,bb,cc文件中匹配test的行。 $ grep '[a-z]' aa // 显示全部包含每一个字符串至少有5个连续小写字符的字符串的行。 $ grep 'w(es)t.*' aa // 若是west被匹配,则es就被存储到内存中,并标记为1,而后搜索任意个字符(.*),这些字符后面紧跟着另一个es(),找到就显示该行。若是用egrep或grep -E,就不用""号进行转义,直接写成'w(es)t.*'就能够了。 $ grep -i pattern files // 不区分大小写地搜索。默认状况区分大小写 $ grep -l pattern files // 只列出匹配的文件名, $ grep -L pattern files // 列出不匹配的文件名, $ grep -w pattern files // 只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’), $ grep -C number pattern files // 匹配的上下文分别显示[number]行, $ grep pattern1 | pattern2 files // 显示匹配 pattern1 或 pattern2 的行, $ grep pattern1 files | grep pattern2 // 显示既匹配 pattern1 又匹配 pattern2 的行。
http://www.cnblogs.com/skynet/archive/2010/12/25/1916873.html
http://www.javashuo.com/article/p-slbokiqm-du.html