当前位置:Linux教程 - Linux资讯 - Linux循序渐进(7)

Linux循序渐进(7)

  第十课(二)文件内容查询命令        grep、fgrep和egrep命令    这组命令以指定模式搜索文件,并通知用户在什么文件中搜索到与指定的模式匹配的字符串,并打印出所有包含该字符串的文本行,在该文本行的最前面是该行所在的文件名。grep命令一次只能搜索一个指定的模式;egrep命令检索扩展的正则表达式(包括表达式组和可选项);fgrep命令检索固定字符串,它不识别正则表达式,是快速搜索命令。    这组命令在搜索与定位文件中特定的主题方面非常有用。要搜索的模式可以被认为是一些关键词,您可以用它们来搜索文件中包含的这些关键词。编写程序时,可以用它来寻找某一个函数,或是相关的词组。grep命令的搜索功能比fgrep强大,因为grep命令的搜索模式可以是正则表达式,而fgrep却不能。有关正则表达式请参见shell一章。    该组命令中的每一个命令都有一组选项,利用这些选项可以改变其输出方式。例如,可以在搜索到的文本行上加入行号,或者只输出文本行的行号,或者输出所有与搜索模式不匹配的文本行,或只简单地输出已搜索到指定模式的文件名,并且可以指定在查找模式时忽略大小写。    这组命令在指定的输入文件中查找与模式匹配的行。如果没有指定文件,则从标准输入中读取。正常情况下,每个匹配的行被显示到标准输出。如果要查找的文件是多个,则在每一行输出之前加上文件名。    语法:    grep [选项] [查找模式] [文件名1,文件名2,……]    egrep [选项] [查找模式] [文件名1,文件名2,……]    fgrep [选项] [查找模式] [文件名1,文件名2,……]    这组命令各选项的含义为:    - E 每个模式作为一个扩展的正则表达式对待。    - F 每个模式作为一组固定字符串对待(以新行分隔),而不作为正则表达式。    - b在输出的每一行前显示包含匹配字符串的行在文件中的字节偏移量。    - c 只显示匹配行的数量。    - i 比较时不区分大小写。    - h 在查找多个文件时,指示grep不要将文件名加入到输出之前。    - l 显示首次匹配串所在的文件名并用换行符将其隔开。当在某文件中多次出现匹配串时,不重复显示此文件名。    - n 在输出前加上匹配串所在行的行号(文件首行行号为1)。    - v 只显示不包含匹配串的行。    - x 只显示整行严格匹配的行。    - e eXPression 指定检索使用的模式。用于防止以“-”开头的模式被解释为命令选项。    - f expfile 从expfile文件中获取要搜索的模式,一个模式占一行。    对该组命令的使用还需注意以下方面:    在命令后键入搜索的模式,再键入要搜索的文件。其中,文件名列表中也可以使用特殊字符,如“*”等,用来生成文件名列表。如果想在搜索的模式中包含有空格的字符串,可以用单引号把要搜索的模式括起来,用来表明搜索的模式是由包含空格的字符串组成。否则,Shell将把空格认为是命令行参数的定界符,而grep命令将把搜索模式中的单词解释为文件名列表中的一部分。在下面的例子中,grep命令在文件example中搜索模式“text file”。    $ grep 'text file' example     用户可以在命令行上用Shell特殊字符来生成将要搜索的文件名列表。在下面的例子中,特殊字符“*”用来生成一个文件名列表,该列表包含当前目录下所有的文件。该命令将搜索出当前目录下所有文件中与模式匹配的行。    $ grep data *     特殊字符在搜索一组指定的文件时非常有用。例如,如果想搜索所有的C程序源文件中特定的模式,您可以用“*.c”来指定文件名列表。假设用户的 C程序中包含一些不必要的转向语句(goto语句),想要找到这些语句,可以用如下的命令来搜索并显示所有包含goto语句的代码行:    $ grep goto *.c    用户可以在命令行上键入搜索模式,也可以使用-f选项从指定文件中读取要搜索的模式。在文件中,每个搜索模式占一行。如果经常要搜索一组常见字符串时,这个功能非常有用。在下面的例子中,用户要在文件exam中搜索字符串“editor”和“create”,就把要搜索的模式放置在文件mypats中,然后,grep命令从文件mypats中读取要搜索的模式。    $ cat mypats    editor    create    $ grep -f mypats exam    文件查找命令    find命令    功能:在目录结构中搜索文件,并执行指定的操作。此命令提供了相当多的查找条件,功能很强大。
[1] [2] [3] 下一页 

   语法:find 起始目录 寻找条件 操作    说明:find命令从指定的起始目录开始,递归地搜索其各个子目录,查找满足寻找条件的文件并对之采取相关的操作。    该命令提供的寻找条件可以是一个用逻辑运算符not、and、or组成的复合条件。逻辑运算符and、or、not的含义为:    (1)and:逻辑与,在命令中用“-a”表示,是系统缺省的选项,表示只有当所给的条件都满足时,寻找条件才算满足。例如:    $ find –name 'tmp' –xtype c -user 'inin'    该命令寻找三个给定条件都满足的所有文件。    (2)or:逻辑或,在命令中用“-o”表示。该运算符表示只要所给的条件中有一个满足时,寻找条件就算满足。例如:    $ find –name 'tmp' –o –name 'mina*'    该命令查询文件名为'tmp'或是匹配'mina*'的所有文件。    (3)not:逻辑非,在命令中用“!”表示。该运算符表示查找不满足所给条件的文件。例如:    $ find ! –name 'tmp'    该命令查询文件名不是'tmp'的所有文件。    需要说明的是:当使用很多的逻辑选项时,可以用括号把这些选项括起来。为了避免Shell本身对括号引起误解,在话号前需要加转义字符“”来去除括号的意义。    例:$ find (–name 'tmp' –xtype c -user 'inin' )    寻找条件有以下选项:    首先,下列各个选项中的n值可以有三种输入方式,假设n为20,则:    +20 表示20以后(21,22,23等)    -20 表示20以前(19,18,17等)    20 表示正好是20    1. 以名称和文件属性查找。    - name '字串' 查找文件名匹配所给字串的所有文件,字串内可用通配符*、?、[ ]。    - lname '字串' 查找文件名匹配所给字串的所有符号链接文件,字串内可用通配符*、?、[ ]。    -gid n 查找属于ID号为n的用户组的所有文件。    -uid n 查找属于ID号为n的用户的所有文件。    -group '字串' 查找属于用户组名为所给字串的所有的文件。    -user '字串' 查找属于用户名为所给字串的所有的文件。    -empty 查找大小为0的目录或文件。    -path '字串' 查找路径名匹配所给字串的所有文件,字串内可用通配符*、?、[ ]。    -perm 权限 查找具有指定权限的文件和目录,权限的表示可以如711,644。    -size n[bckw] 查找指定文件大小的文件,n后面的字符表示单位,缺省为b,代表512字节的块。    -type x 查找类型为x的文件,x为下列字符之一:    b 块设备文件    c 字符设备文件    d 目录文件    p 命名管道(FIFO)    f 普通文件    l 符号链接文件(symbolic links)    s socket文件    -xtype x 与-type基本相同,但只查找符号链接文件。    2. 以时间为条件查找    - amin n 查找n分钟以前被访问过的所有文件。    - atime n 查找n天以前被访问过的所有文件。    - cmin n 查找n分钟以前文件状态被修改过的所有文件。    - ctime n 查找n天以前文件状态被修改过的所有文件。    - mmin n 查找n分钟以前文件内容被修改过的所有文件。    - mtime n 查找n天以前文件内容被修改过的所有文件。    3. 可执行的操作    - exec 命令名称 {} 对符合条件的文件执行所给的Linux 命令,而不询问用户是否需要执行该命令。{}表示命令的参数即为所找到的文件;命令的末尾必须以“ ;”结束。    - ok 命令名称 { } 对符合条件的文件执行所给的Linux 命令,与exec不同的是,它会询问用户是否需要执行该命令。    - ls 详细列出所找到的所有文件。    - fprintf 文件名 将找到的文件名写入指定文件。    - print 在标准输出设备上显示查找出的文件名。
上一页 [1] [2] [3] 下一页 

   - printf 格式 格式的写法请参考有

(出处:http://www.sheup.com)


上一页 [1] [2] [3]