澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

ubuntu内容寻觅,ubuntu系统汉语件和剧情找寻命令

2019-06-08 作者:服务器运维   |   浏览(174)

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字节以上的文件系统)。

find / -name filename 再根目录里面搜索文件名为filename的文件

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

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

find命令的一般形式为;

find /etc -name *s*在目录里面搜索带有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 - 目录。

ubuntu内容寻觅,ubuntu系统汉语件和剧情找寻命令总计。按类型查找  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*ubuntu内容寻觅,ubuntu系统汉语件和剧情找寻命令总计。" -exec grep "sam" { } /;

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

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

本文由澳门新萄京官方网站发布于服务器运维,转载请注明出处:ubuntu内容寻觅,ubuntu系统汉语件和剧情找寻命令

关键词: