veket官方网站论坛

veket

 找回密码
 要注册
搜索
楼主: gfbmgy

linux文件管理

[复制链接]
 楼主| 发表于 2010-4-24 15:39 | 显示全部楼层
  3.less命令

  less命令的功能几乎和more命令一样,也是用来按页显示文件,不同之处在于,less命令在显示文件时允许用户既可以向前又可以向后翻阅文件。

  less命令的使用与more命令类似,在此就不赘述了,用户如有不清楚的地方可直接查看帮助。

  用less命令显示文件时,若需要在文件中往前移动,按【b】键;要移动到用文件的百分比表示的某位置,则指定一个0~100之间的数,并按【p】键即可。

  例如,需要按页显示test文件:

  $ less test
 楼主| 发表于 2010-4-24 15:39 | 显示全部楼层
 4.head命令

  如果用户希望查看一个文件究竟保存的是什么内容,可以只查看文件的头几行,而不必浏览整个文件。用head命令只显示文件或标准输入的头几行。

  语法:head [- n ] 文件

  功能:显示指定文件的前n行。

  说明:该命令显示每个指定文件的前面n行。如果没有给出n值,默认为10。如果没有指定文件,head就从标准输入读取。

  例如,显示文件example.c的前3行:

  $ head - 3 example.c

  /*-------------------------------------------*/

  /* example1.c */

  /*-------------------------------------------*/
 楼主| 发表于 2010-4-24 15:39 | 显示全部楼层
  5.tail命令

  同样,如果用户想查看文件的尾部,可以使用tail命令。

  语法:tail [+ / - num ] [参数] 文件

  说明:该命令显示一个文件的指定内容。它把指定文件的指定显示范围内的内容显示在标准输出上。如果没有给定文件名,则使用标准输入文件。

  tail命令中各个选项的含义为:

  +num 从第num行以后开始显示。

  - num 从距文件尾num行处开始显示。如果省略num参数,系统默认值为10。

  l 以文本行为num的计数单位。与参数选项+num或- num选项同时使用时,num表示要显示的文本行行数。

  c 以字节为num的计数单位。与参数选项+num或- num选项同时使用时,num表示要显示的字符数。

  L, c选项可以省略,系统默认值为l,即按行计数。
 楼主| 发表于 2010-4-24 15:40 | 显示全部楼层
  6 . od命令

  用户通常使用od命令查看特殊格式的文件内容。通过指定该命令的不同选项可以以十进制、八进制、十六进制和ASCII码来显示文件。

  语法:od [选项] 文件

  命令中各选项的含义:

  - A 指定地址基数,包括:

  d(十进制);o(八进制,系统默认值);x(十六进制)。

  n 不显示位移值。

  - t 指定资料的显示格式,主要的参数有:

  c ASCII字符或反斜杠序列;

  d 有符号十进制数字;

  f 浮点数;

  o 八进制(系统默认值为02);

  u 无符号十进位数字;

  x 十六进位数;

  除了选项c以外的其他选项后面都可以跟一个十进制数字n,指定每个显示值所包含的字节数。

  说明:od命令系统默认的显示方式是八进制,这也是该命令的名称由来(Octal Dump)。但这不是最有用的显示方式,用ASCII码和十六进制组合的方式能提供更有价值的信息输出。
 楼主| 发表于 2010-4-24 15:40 | 显示全部楼层
 7.grep、fgrep和egrep命令

  这组命令以指定模式搜索文件,并通知用户在什么文件中搜索到与指定的模式匹配的字串,并显示出所有包含该字串的文本行,在该文本行的最前面是该行所在的文件名。grep命令一次只能搜索一个指定的模式;egrep命令检索扩展的正则运算式(包括运算式组和可选项);fgrep命令检索固定字串,它不识别正则运算式,是快速搜索命令。

  这组命令在搜索与定位文件中特定的主题方面非常有用。要搜索的模式可以被认为是一些关键字,您可以用它们来搜索文件中包含的这些关键字。编写程序时,可以用它来寻找某一个函数或相关的片段。grep命令的搜索功能比fgrep强大,因为grep命令的搜索模式可以是正则运算式,而fgrep却不能。

  该组命令中的每一个命令都有一组选项,利用这些选项可以改变其输出方式。例如,可以在搜索到的文本行上加入行号;只输出文本行的行号;输出所有与搜索模式不匹配的文本行;只简单地输出已搜索到指定模式的文件名,并且可以指定在查找模式时忽略大小写。

  这组命令在指定的输入文件中查找与模式匹配的行。如果没有指定文件,则从标准输入中读取。正常情况下,每个匹配的行被显示到标准输出。如果要查找的文件是多个,则在每一行输出之前加上文件名。

  语法:

  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
您需要登录后才可以回帖 登录 | 要注册

本版积分规则

QQ|手机版|Archiver|veket官方网站论坛 ( 粤ICP备 11052856 )

GMT+8, 2024-5-5 04:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表