ImageVerifierCode 换一换
格式:DOCX , 页数:19 ,大小:28.15KB ,
资源ID:26469876      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/26469876.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(cat和grep指令.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

cat和grep指令.docx

1、cat和grep指令cat命令功能 1: 在标准输出上显示文件。语法:cat 选项 文件说明:该命令功能之一是用来显示文件。它依次读取其后所指文件的内容并将其输出到标准输出。该命令的各选项含义如下:-v 用一种特殊形式显示控制字符,LFD与TAB除外。 加了-v 选项后,-T 和 -E 选项将起作用。其中:-T 将TAB显示为 “ I”。该选项需要与 -v 选项一起使用。即如果没有使用 -v 选项,则这个选项将被忽略。-E 在每行的末尾显示一个符。该选项需要与 -v 选项一起使用。-u 输出不经过缓冲区。-A 等于 -vET。-t 等于 -vT。-e 等于 -vE。-n 在文件的每行前面显示行

2、号。指令实例:cat example.txt / 则在屏幕上显示出example.txt 文件的内容cat -A exam2.txt/ 在屏幕上显示出exam2.txt 文件的内容,而且如果文件中含有特殊字符的话,一并显示功能 2:连接两个或多个文件说明:该命令功能之二是用来将两个或多个文件连接起来。cat file1 file2 file3/ 这样就把文件filel和文件file2的内容合并起来,放入文件file3中。(此时在屏幕上并不能直接看到该命令执行后的结果。若想看到连接后的文件内容, 可以再使用“cat file3”。)需要说明的是,当文件内容过多时,就带来一个问题,因为文本在屏幕上

3、迅速地闪过,用户来不及看清其内容。因此,当文件内容较大时,一般可用more等命令分屏显示,以免因屏幕滚动太快而无法看清。linux grep命令1.作用Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。2.格式grep options3.主要参数options主要参数:c:只输出匹配行的计数。I:不区分大 小写(只适用于单字符)。h:查询多文件时不显示文件名。l:查询多文件时只输出包含匹配字符的文件名。n:显示匹配

4、行及 行号。s:不显示不存在或无匹配文本的错误信息。v:显示不包含匹配文本的所有行。pattern正则表达式主要参数: 忽略正则表达式中特殊字符的原有含义。:匹配正则表达式的开始行。$: 匹配正则表达式的结束行。:到匹配正则表达式的行结束。 :单个字符,如A即A符合要求 。 - :范围,如A-Z,即A、B、C一直到Z都符合要求 。:所有的单个字符。* :有字符,长度可以为0。4.grep命令使用简单实例$ grep test d*显示所有以d开头的文件中包含 test的行。$ grep test aa bb cc显示在aa,bb,cc文件中匹配test的行。$ grep a-z5 aa显示所有

5、包含每个字符串至少有5个连续小写字符的字符串的行。$ grep w(es)t.*1 aa如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着 另外一个es(1),找到就显示该行。如果用egrep或grep -E,就不用”号进行转义,直接写成w(es)t.*1就可以了。5.grep命令使用复杂实例假设您正在/usr/src/Linux/Doc目录下搜索带字符 串magic的文件:$ grep magic /usr/src/Linux/Doc/*sysrq.txt:* How do I enable the magic SysRQ key?sysr

6、q.txt:* How do I use the magic SysRQ key?其中文件sysrp.txt包含该字符串,讨论的是 SysRQ 的功能。默认情况下,grep只搜索当前目录。如果 此目录下有许多子目录,grep会以如下形式列出:grep: sound: Is a directory这可能会使grep 的输出难于阅读。这里有两种解决的办法:明确要求搜索子目录:grep -r或忽略子目录:grep -d skip如果有很多 输出时,您可以通过管道将其转到less上阅读:$ grep magic /usr/src/Linux/Documentation/* | less这样,您就可以更

7、方便地阅读。有一点要注意,您必需提供一个文件过滤方式(搜索全部文件的话用 *)。如果您忘了,grep会一直等着,直到该程序被中断。如果您遇到了这样的情况,按 ,然后再试。下面还有一些有意思的命令行参数:grep -i pattern files :不区分大小写地搜索。默认情况区分大小写,grep -l pattern files :只列出匹配的文件名,grep -L pattern files :列出不匹配的文件名,grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配magic,而不是magical),grep -C number pattern file

8、s :匹配的上下文分别显示number行,grep pattern1 | pattern2 files :显示匹配 pattern1 或 pattern2 的行,grep pattern1 files | grep pattern2 :显示既匹配 pattern1 又匹配 pattern2 的行。grep -n pattern files 即可显示行号信息grep -c pattern files 即可查找总行数这里还有些用于搜索的特殊符号: 分别标注单词的开始与结尾。例如:grep man * 会匹配 Batman、manic、man等,grep man * 匹配manic和man,但不是B

9、atman,grep 只匹配man,而不是Batman或manic等其他的字符串。:指匹配的字符串在行首,$:指匹配的字符串在行 尾,Unix grep指令简介grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep

10、或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。grep常用用法rootwww # grep -acinv -color=auto 搜寻字符串 filename选项与参数:-a :将 binary 文件以 text 文件的方式搜寻数据-c :计算找到 搜寻字符串 的次数-i :忽略大小写的不同,所以大小写视为相同-n :顺便输出行号-v :反向选择,亦即显示出没有 搜寻字符串 内容的那一行!-color=auto

11、 :可以将找到的关键词部分加上颜色的显示喔!将/etc/passwd,有出现 root 的行取出来# grep root /etc/passwdroot:x:0:0:root:/root:/bin/bashoperator:x:11:0:operator:/root:/sbin/nologin或# cat /etc/passwd | grep root root:x:0:0:root:/root:/bin/bashoperator:x:11:0:operator:/root:/sbin/nologin将/etc/passwd,有出现 root 的行取出来,同时显示这些行在/etc/passwd

12、的行号# grep -n root /etc/passwd1:root:x:0:0:root:/root:/bin/bash30:operator:x:11:0:operator:/root:/sbin/nologin在关键字的显示方面,grep 可以使用 -color=auto 来将关键字部分使用颜色显示。 这可是个很不错的功能啊!但是如果每次使用 grep 都得要自行加上 -color=auto 又显的很麻烦 此时那个好用的 alias 就得来处理一下啦!你可以在 /.bashrc 内加上这行:alias grep=grep -color=auto再以 source /.bashrc 来立

13、即生效即可喔! 这样每次运行 grep 他都会自动帮你加上颜色显示啦将/etc/passwd,将没有出现 root 的行取出来# grep -v root /etc/passwdroot:x:0:0:root:/root:/bin/bashoperator:x:11:0:operator:/root:/sbin/nologin将/etc/passwd,将没有出现 root 和nologin的行取出来# grep -v root /etc/passwd | grep -v nologinroot:x:0:0:root:/root:/bin/bashoperator:x:11:0:operator

14、:/root:/sbin/nologin用 dmesg 列出核心信息,再以 grep 找出内含 eth 那行,要将捉到的关键字显色,且加上行号来表示:rootwww # dmesg | grep -n -color=auto eth247:eth0: RealTek RTL8139 at 0xee846000, 00:90:cc:a6:34:84, IRQ 10248:eth0: Identified 8139 chip type RTL-8139C294:eth0: link up, 100Mbps, full-duplex, lpa 0xC5E1305:eth0: no IPv6 rout

15、ers present# 你会发现除了 eth 会有特殊颜色来表示之外,最前面还有行号喔!在关键字的显示方面,grep 可以使用 -color=auto 来将关键字部分使用颜色显示。 这可是个很不错的功能啊!但是如果每次使用 grep 都得要自行加上 -color=auto 又显的很麻烦 此时那个好用的 alias 就得来处理一下啦!你可以在 /.bashrc 内加上这行:alias grep=grep -color=auto再以 source /.bashrc 来立即生效即可喔! 这样每次运行 grep 他都会自动帮你加上颜色显示啦用 dmesg 列出核心信息,再以 grep 找出内含 et

16、h 那行,在关键字所在行的前两行与后三行也一起捉出来显示rootwww # dmesg | grep -n -A3 -B2 -color=auto eth245-PCI: setting IRQ 10 as level-triggered246-ACPI: PCI Interrupt 0000:00:0e.0A - Link LNKB .247:eth0: RealTek RTL8139 at 0xee846000, 00:90:cc:a6:34:84, IRQ 10248:eth0: Identified 8139 chip type RTL-8139C249-input: PC Speak

17、er as /class/input/input2250-ACPI: PCI Interrupt 0000:00:01.4B - Link LNKB .251-hdb: ATAPI 48X DVD-ROM DVD-R-RAM CD-R/RW drive, 2048kB Cache, UDMA(66)# 如上所示,你会发现关键字 247 所在的前两行及 248 后三行也都被显示出来!# 这样可以让你将关键字前后数据捉出来进行分析啦!根据文件内容递归查找目录# grep energywise * #在当前目录搜索带energywise行的文件# grep -r energywise * #在当前目

18、录及其子目录下搜索energywise行的文件# grep -l -r energywise * #在当前目录及其子目录下搜索energywise行的文件,但是不显示匹配的行,只显示匹配的文件这几个命令很使用,是查找文件的利器。grep与正规表达式字符类字符类的搜索:如果我想要搜寻 test 或 taste 这两个单字时,可以发现到,其实她们有共通的 t?st 存在这个时候,我可以这样来搜寻:rootwww # grep -n taest regular_express.txt8:I cant finish the test.9:Oh! The soup taste good.其实 里面不论有

19、几个字节,他都谨代表某一个字节, 所以,上面的例子说明了,我需要的字串是tast或test两个字串而已!字符类的反向选择 :如果想要搜索到有 oo 的行,但不想要 oo 前面有 g,如下rootwww # grep -n goo regular_express.txt2:apple is my favorite food.3:Football game is not use feet only.18:google is the best tools for search keyword.19:goooooogle yes!第 2,3 行没有疑问,因为 foo 与 Foo 均可被接受!但是第 1

20、8 行明明有 google 的 goo 啊别忘记了,因为该行后面出现了 tool 的 too 啊!所以该行也被列出来 也就是说, 18 行里面虽然出现了我们所不要的项目 (goo) 但是由於有需要的项目 (too) , 因此,是符合字串搜寻的喔!至於第 19 行,同样的,因为 goooooogle 里面的 oo 前面可能是 o ,例如: go(ooo)oogle ,所以,这一行也是符合需求的!字符类的连续:再来,假设我 oo 前面不想要有小写字节,所以,我可以这样写 abcd.zoo , 但是这样似乎不怎么方便,由於小写字节的 ASCII 上编码的顺序是连续的, 因此,我们可以将之简化为底下这

21、样:rootwww # grep -n a-zoo regular_express.txt3:Football game is not use feet only.也就是说,当我们在一组集合字节中,如果该字节组是连续的,例如大写英文/小写英文/数字等等, 就可以使用a-z,A-Z,0-9等方式来书写,那么如果我们的要求字串是数字与英文呢? 呵呵!就将他全部写在一起,变成:a-zA-Z0-9。我们要取得有数字的那一行,就这样:rootwww # grep -n 0-9 regular_express.txt5:However, this dress is about $ 3183 dollars

22、.15:You are the best is mean you are the no. 1.行首与行尾字节 $行首字符:如果我想要让 the 只在行首列出呢? 这个时候就得要使用定位字节了!我们可以这样做:rootwww # grep -n the regular_express.txt12:the symbol * is represented as start.此时,就只剩下第 12 行,因为只有第 12 行的行首是 the 开头啊此外, 如果我想要开头是小写字节的那一行就列出呢?可以这样:rootwww # grep -n a-z regular_express.txt2:apple

23、is my favorite food.4:this dress doesnt fit me.10:motorcycle is cheap than car.12:the symbol * is represented as start.18:google is the best tools for search keyword.19:goooooogle yes!20:go! go! Lets go.如果我不想要开头是英文字母,则可以是这样:rootwww # grep -n a-zA-Z regular_express.txt1:Open Source is a good mechanis

24、m to develop programs.21:# I am VBird 符号,在字符类符号(括号)之内与之外是不同的! 在 内代表反向选择,在 之外则代表定位在行首的意义!那如果我想要找出来,行尾结束为小数点 (.) 的那一行:rootwww # grep -n .$ regular_express.txt1:Open Source is a good mechanism to develop programs.2:apple is my favorite food.3:Football game is not use feet only.4:this dress doesnt fit m

25、e.10:motorcycle is cheap than car.11:This window is clear.12:the symbol * is represented as start.15:You are the best is mean you are the no. 1.16:The world is the same with glad.17:I like dog.18:google is the best tools for search keyword.20:go! go! Lets go.特别注意到,因为小数点具有其他意义(底下会介绍),所以必须要使用转义字符()来加以

26、解除其特殊意义!找出空白行:rootwww # grep -n $ regular_express.txt22:因为只有行首跟行尾 ($),所以,这样就可以找出空白行啦!任意一个字节 . 与重复字节 *这两个符号在正则表达式的意义如下:. (小数点):代表一定有一个任意字节的意思;* (星号):代表重复前一个字符, 0 到无穷多次的意思,为组合形态假设我需要找出 g?d 的字串,亦即共有四个字节, 起头是 g 而结束是 d ,我可以这样做:rootwww # grep -n g.d regular_express.txt1:Open Source is a good mechanism to

27、develop programs.9:Oh! The soup taste good.16:The world is the same with glad.因为强调 g 与 d 之间一定要存在两个字节,因此,第 13 行的 god 与第 14 行的 gd 就不会被列出来啦!如果我想要列出有 oo, ooo, oooo 等等的数据, 也就是说,至少要有两个(含) o 以上,该如何是好?因为 * 代表的是重复 0 个或多个前面的 RE 字符的意义, 因此,o*代表的是:拥有空字节或一个 o 以上的字节,因此, grep -n o* regular_express.txt 将会把所有的数据都列印出来

28、终端上!当我们需要至少两个 o 以上的字串时,就需要 ooo* ,亦即是:rootwww # grep -n ooo* regular_express.txt1:Open Source is a good mechanism to develop programs.2:apple is my favorite food.3:Football game is not use feet only.9:Oh! The soup taste good.18:google is the best tools for search keyword.19:goooooogle yes!如果我想要字串开头与结

29、尾都是 g,但是两个 g 之间仅能存在至少一个 o ,亦即是 gog, goog, gooog. 等等,那该如何?rootwww # grep -n goo*g regular_express.txt18:google is the best tools for search keyword.19:goooooogle yes!如果我想要找出 g 开头与 g 结尾的行,当中的字符可有可无rootwww # grep -n g.*g regular_express.txt1:Open Source is a good mechanism to develop programs.14:The gd software is a library for drafting programs.18:google is the best tools for search keyword.19:goooooogle yes!20:go! go! Lets go.因为是代表 g 开头与 g 结尾,中间任意字节均可接受,所以,第 1, 14, 20 行是可接受的喔! 这个 .* 的 RE 表示任意字符是很常见的.如果我想要找出任意数字的行?因为仅有数字,所以就成为:rootwww # grep -n 0-90-9* regu

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1