您的位置:新葡亰496net > 服务器网络 > ubuntu系统汉语件和内容寻找命令总计,ubuntu寻觅

ubuntu系统汉语件和内容寻找命令总计,ubuntu寻觅

发布时间:2019-06-19 08:49编辑:服务器网络浏览(85)

    ubuntu系统中文件和内容查找命令小结,ubuntu内容查找

    本文章总结了ubuntu系统中文件和内容查找命令,如有 find、locate、which、grep等文件与内容查找命令的介绍,有需要的同学可参考本文章 一.以文件名查找:  1. find 命令 

    由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。即使系统中含有网络文件系统( NFS),find命令在该文件系统中同样有效,只你具有相应的权限。 
    在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统)。 
    find命令的一般形式为; 
    find pathname -options [-print -exec -ok ...] 
    如 
    find / -name "filename" 
    目的:在根目录“/”开始搜被称为filename的文件,“filename”文件名可以包含通配符(*,?),注意:filename是文件名字符串,可以带双引号,也可不带find命令功能强大,它有很多选项让你以不同的方式搜索文件,例如,通过日期,文件大小,权限,拥有者等等。 
    find命令的参数; 
    pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。 
    -print: find命令将匹配的文件输出到标准输出。 
    -exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } ;,注意{ }和;之间的空格。 
    -ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。 

    3、find命令选项 

    -name 
    按照文件名查找文件。 
    -perm 
    按照文件权限来查找文件。 
    -prune 
    使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。 
    -user 
    按照文件属主来查找文件。 
    -group 
    按照文件所属的组来查找文件。 
    -mtime -n n 
    按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内, n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。 
    -nogroup 
    查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。 
    -nouser 
    查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。 
    -newer file1 ! file2 
    查找更改时间比文件file1新但比文件file2旧的文件。 
    -type 
    查找某一类型的文件,诸如: 
    b - 块设备文件。 
    d - 目录。 
    c - 字符设备文件。 
    p - 管道文件。 
    l - 符号链接文件。 
    f - 普通文件。 
    -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。 
    -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。 
    -fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。 
    -mount:在查找文件时不跨越文件系统mount点。 
    -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。 
    -cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。 

    2. locate 命令 

    locate filename 
    locate命令其实是“find -name”的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库(/var/lib/locatedb),这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。 
    locate命令的使用实例: 
      $ locate /etc/sh 
    搜索etc目录下所有以sh开头的文件。 
      $ locate ~/m 
    搜索用户主目录下,所有以m开头的文件。 
      $ locate -i ~/m 
    搜索用户主目录下,所有以m开头的文件,并且忽略大小写。 

    发现包含字符串“filename”的文件名。这比find命令更容易。但是基于数据库(通常在夜间重建),所以你无法找到刚刚存到文件系统的文件。为了强制立即更新数据库,作为超级用户可以使用:updatedb& (中间没有空格) 

    3. which命令 

    which executeable_name 
    查找可执行文件,根据可执行文件的文件名。 
    例如 which apache2 , 返回/usr/sbin/apache2 

    二.以文件内容查找 

    1. grep -n 字符串名字 /filepath/filename 
      返回包含该字符串的该行,可以是多行。且包含行数。 
    2. sudo gedit /filepath/filename 
      而后,用ctrl F 去查找相应的字符串。 
    3. vi或者less命令可以查找相应的内容 
      例如 vi /filepath/filename而后,输入 “/字符串” ,按下字母“n”到下一个匹配的字符串 
    4. tail命令 

    查看文件内容的特殊方法

    1. 如果你只想看文件的前5行,可以使用head命令,如: 
      head -5 /etc/passwd 
    2. 如果你想查看文件的后10行,可以使用tail命令,如: 
      tail -20 /etc/passwd 
      tail -f /var/log/messages 
      参数-f使tail不停地去读最新的内容,这样有实时监视的效果 
      tail -f /var/log/messages 
      按Ctrl C后,直接从脚本退出到提示符下了 文章转载自

    本文章总结了ubuntu系统中文件和内容查找命令,如有 find、locate、which、grep等文件与内容查找命令的介绍,有需要的同学可参考本文章。

    ubuntu搜索文件方法(find命令)

    1、locate 

    通用格式:find pathname -options [-print -exec -ok]

    一.以文件名查找:

     

      locate指令和find找寻档案的功能类似,但locate是透过update程序将硬盘中的所有档案和目录资料先建立一个索引数据库,在 执行loacte时直接找该索引,查询速度会较快,索引数据库一般是由操作系统管理,但也可以直接下达update强迫系统立即修改索引数据库。

    例子:
    find / -name filename 再根目录里面搜索文件名为filename的文件
    find /etc -name *s*在目录里面搜索带有s的文件
    find /etc -name *S 在目录里面搜索以s结尾的文件
    find /etc -name s*在目录里面搜索以s开头的文件
    find / -amin -10在系统中搜索最后10分钟访问的文件
    find / -atime -2查找在系统中最后48小时访问的文件
    find / -empty 查找在系统中为空的文件或者是文件夹
    find / -group groupname 查找在系统中属于groupname的文件
    find / -mmin -5查找在系统中最后5分钟修改过的文件
    find / -mtime -1查找在系统中最后24小时修改过的文件
    find /-nouser查找在系统中属于费用户的文件
    find / -user username 查找在系统中属于username的文件
    find / -ctime -1查找在系统中最后24小时被改变状态的文件
    find / -fstype type查找在系统中文件类型为?的文件
    find / -user user1name -or -user user2name查找在系统中属于user1name或着属于user2name的文件
    find / -user user1name -and -user2name在系统中查找既属于user1name又属于user2name用户的文件.

    1. find 命令

    通用格式:find pathname -options [-print -exec -ok]

    命令参数:

    一、find 命令格式

    由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。即使系统中含有网络文件系统( NFS),find命令在该文件系统中同样有效,只你具有相应的权限。

    例子:

    -e   将排除在寻找的范围之外。

    1、find命令的一般形式为;

    在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统)。

    ubuntu系统汉语件和内容寻找命令总计,ubuntu寻觅文件措施。find / -name filename 再根目录里面搜索文件名为filename的文件

    -1  如果 是 1.则启动安全模式。在安全模式下,使用者不会看到权限无法看到 的档案。这会始速度减慢,因为 locate 必须至实际的档案系统中取得档案的 权限资料。

    find pathname -options [-print -exec -ok ...]

    find命令的一般形式为;

    find /etc -name *s*ubuntu系统汉语件和内容寻找命令总计,ubuntu寻觅文件措施。在目录里面搜索带有s的文件

    -f   将特定的档案系统排除在外,例如我们没有到理要把 proc 档案系统中的档案 放在资料库中。

    2、find命令的参数;

    find pathname -options [-print -exec -ok ...]

    find /etc -name *S 在目录里面搜索以s结尾的文件

    -q  安静模式,不会显示任何错误讯息。

    pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
    -print: find命令将匹配的文件输出到标准输出。
    -exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } ;,注意{ }和;之间的空格。
    -ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

    find /etc -name s*在目录里面搜索以s开头的文件

    -n 至多显示 n个输出。

    3、find命令选项

    find  /  -name  "filename"

    find / -amin -10在系统中搜索最后10分钟访问的文件

    -r 使用正规运算式 做寻找的条件。

    -name
    按照文件名查找文件。
    -perm
    按照文件权限来查找文件。
    -prune
    使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。
    -user
    按照文件属主来查找文件。
    -group
    按照文件所属的组来查找文件。
    -mtime -n n
    按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内, n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。
    -nogroup
    查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。
    -nouser
    查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。
    -newer file1 ! file2
    查找更改时间比文件file1新但比文件file2旧的文件。
    -type
    查找某一类型的文件,诸如:
    b - 块设备文件。
    d - 目录。
    c - 字符设备文件。
    p - 管道文件。
    l - 符号链接文件。
    f - 普通文件。
    -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。
    -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。
    -fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。
    -mount:在查找文件时不跨越文件系统mount点。
    -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。
    -cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。

    目的:在根目录“/”开始搜被称为filename的文件,“filename”文件名可以包含通配符(*,?),注意:filename是文件名字符串,可以带双引号,也可不带find命令功能强大,它有很多选项让你以不同的方式搜索文件,例如,通过日期,文件大小,权限,拥有者等等。
    find命令的参数;

    find / -atime -2查找在系统中最后48小时访问的文件

    -o 指定资料库存的名称。

    另外,下面三个的区别:
      -amin n
    查找系统中最后N分钟访问的文件
    -atime n
    查找系统中最后n*24小时访问的文件
    -cmin n
    查找系统中最后N分钟被改变文件状态的文件
    -ctime n
    查找系统中最后n*24小时被改变文件状态的文件
       -mmin n
    查找系统中最后N分钟被改变文件数据的文件
    -mtime n
    查找系统中最后n*24小时被改变文件数据的文件

    pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
    -print: find命令将匹配的文件输出到标准输出。
    -exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } ;,注意{ }和;之间的空格。
    -ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

    find / -empty 查找在系统中为空的文件或者是文件夹

    -d 指定资料库的路径

    4、使用exec或ok来执行shell命令

    3、find命令选项

    find / -group groupname 查找在系统中属于groupname的文件

    -h 显示辅助讯息

    使用find时,只要把想要的操作写在一个文件里,就可以用exec来配合find查找,很方便的

    -name
    按照文件名查找文件。
    -perm
    按照文件权限来查找文件。
    -prune
    使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。
    -user
    按照文件属主来查找文件。
    -group
    按照文件所属的组来查找文件。
    -mtime -n n
    按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内, n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。
    -nogroup
    查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。
    -nouser
    查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。
    -newer file1 ! file2
    查找更改时间比文件file1新但比文件file2旧的文件。
    -type
    查找某一类型的文件,诸如:
    b - 块设备文件。
    d - 目录。
    c - 字符设备文件。
    p - 管道文件。
    l - 符号链接文件。
    f - 普通文件。
    -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。
    -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。
    -fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。
    -mount:在查找文件时不跨越文件系统mount点。
    -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。
    -cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。  

    find / -mmin -5查找在系统中最后5分钟修改过的文件

    -V 显示程式的版本讯息

    在有些操作系统中只允许-exec选项执行诸如l s或ls -l这样的命令。大多数用户使用这一选项是为了查找旧文件并删除它们。建议在真正执行rm命令删除文件之前,最好先用ls命令看一下,确认它们是所要删除的文件。

    1. locate 命令

    find / -mtime -1查找在系统中最后24小时修改过的文件

    使用实例:

    exec选项后面跟随着所要执行的命令或脚本,然后是一对儿{ },一个空格和一个,最后是一个分号。为了使用exec选项,必须要同时使用print选项。如果验证一下find命令,会发现该命令只输出从当前路径起的相对路径及文件名。

    locate filename

    find /-nouser查找在系统中属于费用户的文件

      locate /etc/sh

    例如:为了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的-exec选项中

    locate命令其实是“find -name”的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库(/var/lib/locatedb),这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。

    find / -user username 查找在系统中属于username的文件

    2、find 

    # find . -type f -exec ls -l { } ;
    -rw-r--r-- 1 root root 34928 2003-02-25 ./conf/httpd.conf
    -rw-r--r-- 1 root root 12959 2003-02-25 ./conf/magic
    -rw-r--r-- 1 root root 180 2003-02-25 ./conf.d/README

    locate命令的使用实例:

    find / -ctime -1查找在系统中最后24小时被改变状态的文件

    Linux下find命令在目录结构中搜索文件,并执行指定的操作。Linux下find命令提供了相当多的查找条件,功能很强大。由于find具有强大的功能,选项也很多,即使系统中含有网络文件系统( NFS),find命令在该文件系统中同样有效,具有相应的权限。 在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统)。

    上面的例子中,find命令匹配到了当前目录下的所有普通文件,并在-exec选项中使用ls -l命令将它们列出。
    在/logs目录中查找更改时间在5日以前的文件并删除它们:

      $ locate /etc/sh

    find / -fstype type查找在系统中文件类型为?的文件

    1.命令格式:

    $ find logs -type f -mtime 5 -exec rm { } ;

    搜索etc目录下所有以sh开头的文件。

    find / -user user1name -or -useruser2name查找在系统中属于user1name或着属于user2name的文件

    find pathname -options [-print -exec -ok ...]

    记住:在shell中用任何方式删除文件之前,应当先查看相应的文件,一定要小心!当使用诸如mv或rm命令时,可以使用-exec选项的安全模式。它将在对每个匹配到的文件进行操作之前提示你。

      $ locate ~/m

    find / -user user1name -and-user2name在系统中查找既属于user1name又属于user2name用户的文件.

    2.命令功能:

    在下面的例子中, find命令在当前目录中查找所有文件名以.LOG结尾、更改时间在5日以上的文件,并删除它们,只不过在删除之前先给出提示。

    搜索用户主目录下,所有以m开头的文件。

     

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

    $ find . -name "*.conf" -mtime 5 -ok rm { } ;
    < rm ... ./conf/httpd.conf > ? n

      $ locate -i ~/m

    一、find 命令格式

    3.命令参数:

    按y键删除文件,按n键不删除。

    搜索用户主目录下,所有以m开头的文件,并且忽略大小写。

     

    pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。 

    任何形式的命令都可以在-exec选项中使用。

     

     

    -print: find命令将匹配的文件输出到标准输出。 

    在下面的例子中我们使用grep命令。find命令首先匹配所有文件名为“ passwd*”的文件,例如passwd、passwd.old、passwd.bak,然后执行grep命令看看在这些文件中是否存在一个sam用户。

    发现包含字符串“filename”的文件名。这比find命令更容易。但是基于数据库(通常在夜间重建),所以你无法找到刚刚存到文件系统的文件。为了强制立即更新数据库,作为超级用户可以使用:updatedb& (中间没有空格)

    1、find命令的一般形式为;

    -exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' {  } ;,注意{   }和;之间的空格。 

    # find /etc -name "passwd*" -exec grep "sam" { } ;
    sam:x:501:501::/usr/sam:/bin/bash

     

     

    -ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

    图片 1

    1. which命令

    find pathname -options [-print -exec -ok ...]

      4.命令选项:

    which executeable_name

     

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

    查找可执行文件,根据可执行文件的文件名。

     

    -perm   按照文件权限来查找文件。

    例如 which apache2 , 返回/usr/sbin/apache2

    2、find命令的参数;

    -prune  使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。

     二.以文件内容查找

     

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

    1. grep  -n  字符串名字  /filepath/filename

    pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。

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

    返回包含该字符串的该行,可以是多行。且包含行数。

    -print: find命令将匹配的文件输出到标准输出。

    -mtime -n  n  按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内,  n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。

    1. sudo  gedit  /filepath/filename

    -exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } /;,注意{}和/;之间的空格。

    -nogroup  查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。

    而后,用ctrl F 去查找相应的字符串。

    -ok:和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

    -nouser   查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。

    1. vi或者less命令可以查找相应的内容

     

    -newer file1 ! file2  查找更改时间比文件file1新但比文件file2旧的文件。

    例如 vi  /filepath/filename而后,输入 “/字符串”  ,按下字母“n”到下一个匹配的字符串

     

    -type  查找某一类型的文件,诸如:

    1. tail命令

    3、find命令选项

    b - 块设备文件。

     查看文件内容的特殊方法

     

    d - 目录。

    1. 如果你只想看文件的前5行,可以使用head命令,如:
      head -5 /etc/passwd
    2. 如果你想查看文件的后10行,可以使用tail命令,如:
      tail -20 /etc/passwd
      tail -f /var/log/messages
      参数-f使tail不停地去读最新的内容,这样有实时监视的效果

    -name

    c - 字符设备文件。

    tail -f /var/log/messages

    按照文件名查找文件。

    p - 管道文件。

    按Ctrl C后,直接从脚本退出到提示符下了

    -perm

    l - 符号链接文件。

    find、locate、which、grep等文件与内容查找命令的介绍,有需要的同学可参考本文章。 一...

    按照文件权限来查找文件。

    f - 普通文件。

    -prune

    -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。-depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。

    使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。

    -fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。

    -user

    -mount:在查找文件时不跨越文件系统mount点。

    按照文件属主来查找文件。

    -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。

    -group

    -cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。

    按照文件所属的组来查找文件。

    另外,下面三个的区别:

    -mtime -n n

    -amin n   查找系统中最后N分钟访问的文件

    按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内, n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。

    -atime n  查找系统中最后n*24小时访问的文件

    -nogroup

    -cmin n   查找系统中最后N分钟被改变文件状态的文件

    查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。

    -ctime n  查找系统中最后n*24小时被改变文件状态的文件

    -nouser

    -mmin n   查找系统中最后N分钟被改变文件数据的文件

    查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。

    -mtime n  查找系统中最后n*24小时被改变文件数据的文件

    -newer file1 ! file2

     

    查找更改时间比文件file1新但比文件file2旧的文件。

     

    -type

    查找指定时间内修改过的文件  find -atime -2

    查找某一类型的文件,诸如:

    根据关键字查找  find . -name "*.log"   在当前目录查找 以.log结尾的文件。 ". "代表当前目录 

    b - 块设备文件。

    按照目录或文件的权限来查找文件  find /opt/soft/test/ -perm 777  查找/opt/soft/test/目录下 权限为 777的文件

    d - 目录。

    按类型查找  find . -type f -name "*.log" 

    c - 字符设备文件。

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

    p - 管道文件。

    按大小查找文件  find . -size  1000c -print  查找当前目录大于1K的文件 

    l - 符号链接文件。

    find之exec 

    f - 普通文件。

    find是我们很常用的一个Linux命令,但是我们一般查找出来的并不仅仅是看看而已,还会有进一步的操作,这个时候exec的作用就显现出来了。

    -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。

    -exec  参数后面跟的是command命令,它的终止是以;为结束标志的,所以这句命令后面的分号是不可缺少的,考虑到各个系统中分号会有不同的意义,所以前面加反斜杠。

    -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。

    使用find时,只要把想要的操作写在一个文件里,就可以用exec来配合find查找,很方便的。在有些操作系统中只允许-exec选项执行诸如l s或ls -l这样的命令。大多数用户使用这一选项是为了查找旧文件并删除它们。建议在真正执行rm命令删除文件之前,最好先用ls命令看一下,确认它们是所要删除的文件。 exec选项后面跟随着所要执行的命令或脚本,然后是一对儿{ },一个空格和一个,最后是一个分号。为了使用exec选项,必须要同时使用print选项。如果验证一下find命令,会发现该命令只输出从当前路径起的相对路径及文件名。

    -fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。

    实例:

    -mount:在查找文件时不跨越文件系统mount点。

    ls -l命令放在find命令的-exec选项中    find . -type f -exec ls -l {} ;   find命令匹配到了当前目录下的所有普通文件,并在-exec选项中使用ls -l命令将它们列出。

    -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。

    在目录中查找更改时间在n日以前的文件并删除它们   find . -type f -mtime  14 -exec rm {} ;  

    -cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。

    在shell中用任何方式删除文件之前,应当先查看相应的文件,一定要小心!当使用诸如mv或rm命令时,可以使用-exec选项的安全模式。它将在对每个匹配到的文件进行操作之前提示你。

     

    在目录中查找更改时间在n日以前的文件并删除它们,在删除之前先给出提示    find . -name "*.log" -mtime  5 -ok rm {} ;

    另外,下面三个的区别:

      -exec中使用grep命令   find /etc -name "passwd*" -exec grep "root" {} ;

     

      查找文件移动到指定目录     find . -name "*.log" -exec mv {} .. ;    删除后cd .. ll 能找到

    -amin n

      用exec选项执行cp命令   find . -name "*.log" -exec cp {} test3 ;   

      查找系统中最后N分钟访问的文件

         

      -atime n

     

      查找系统中最后n*24小时访问的文件

      -cmin n

      查找系统中最后N分钟被改变文件状态的文件

      -ctime n

      查找系统中最后n*24小时被改变文件状态的文件

       -mmin n

      查找系统中最后N分钟被改变文件数据的文件

      -mtime n

      查找系统中最后n*24小时被改变文件数据的文件

     

     

    4、使用exec或ok来执行shell命令

     

    使用find时,只要把想要的操作写在一个文件里,就可以用exec来配合find查找,很方便的

     

    在有些操作系统中只允许-exec选项执行诸如l s或ls-l这样的命令。大多数用户使用这一选项是为了查找旧文件并删除它们。建议在真正执行rm命令删除文件之前,最好先用ls命令看一下,确认它们是所要删除的文件。

     

    exec选项后面跟随着所要执行的命令或脚本,然后是一对儿{},一个空格和一个/,最后是一个分号。为了使用exec选项,必须要同时使用print选项。如果验证一下find命令,会发现该命令只输出从当前路径起的相对路径及文件名。

     

    例如:为了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的-exec选项中

     

    # find . -type f -exec ls -l { } /;

    -rw-r--r-- 1 root root 34928 2003-02-25 ./conf/httpd.conf

    -rw-r--r-- 1 root root 12959 2003-02-25 ./conf/magic

    -rw-r--r-- 1 root root 180 2003-02-25 ./conf.d/README

     

    上面的例子中,find命令匹配到了当前目录下的所有普通文件,并在-exec选项中使用ls -l命令将它们列出。

    在/logs目录中查找更改时间在5日以前的文件并删除它们:

     

    $ find logs -type f -mtime 5 -exec rm { } /;

     

    记住:在shell中用任何方式删除文件之前,应当先查看相应的文件,一定要小心!当使用诸如mv或rm命令时,可以使用-exec选项的安全模式。它将在对每个匹配到的文件进行操作之前提示你。

     

    在下面的例子中,find命令在当前目录中查找所有文件名以.LOG结尾、更改时间在5日以上的文件,并删除它们,只不过在删除之前先给出提示。

     

    $ find . -name "*.conf" -mtime 5 -ok rm { } /;

    < rm ... ./conf/httpd.conf > ?n

     

    按y键删除文件,按n键不删除。

     

    任何形式的命令都可以在-exec选项中使用。

     

    在下面的例子中我们使用grep命令。find命令首先匹配所有文件名为“passwd*”的文件,例如passwd、passwd.old、passwd.bak,然后执行grep命令看看在这些文件中是否存在一个sam用户。

     

    # find /etc -name "passwd*" -exec grep "sam" { } /;

    sam:x:501:501::/usr/sam:/bin/bash

    通用格式:find pathname -options [-print -exec -ok] 例子: find / -name filename 再根目录里面搜索文件名为filename的文件...

    本文由新葡亰496net发布于服务器网络,转载请注明出处:ubuntu系统汉语件和内容寻找命令总计,ubuntu寻觅

    关键词:

上一篇:没有了

下一篇:没有了