这几个工具是shell中非常好用的文本流处理工具,可以进行查找,编辑或者分析等工作,它们都支持,也支持使用shell内置的变量
grep
grep是一个字符串比较工具,用于从文件中提取满足条件的行,条件的部分可以使用正则表达式
$grep [-ABrn] [str] FilePathOrDirPath
VS $find [路径] [选项] [参数]
-A [n]
#除了该行之外,也列出后续的n行-B [n]
#除了该行之外,也列出之前的n行-n
#显示行号-r
#递归查找所有的目录 示例文档 $ cat -n test_grep 1 #include2 int main(){ 3 printf("hello,world!"); 4 } 5 6 7 角标 8 见后文[^1] 9 10 [^1]:This the first footnote 11
栗子, 找到符合模式[a-g](的行:
$ grep '[a-g](' test_grep printf("hello,world!");
sed
sed是一个文本流编辑工具,对文件流以行为单位进行替换,删除,新增,提取等操作
$sed [-nefri] [n1[, n2]] [function] [字符串]
-n
只列出经过sed特殊处理的那一行-e
直接使用命令行对文本流进行编辑,即使用function-f
直接将sed编辑好的文本流写入一个文件-i
直接编辑文件内容,不在屏幕输出 function的内容: a\ :add, 将后接的字符串添加到[n1,n2]的下一行
c: change,,用后接的字符串替代[n1, n2]之间的行d :delete, 删除n1, n2之间的行i\ :insert, 将后接的字符串添加到[n1, n2]的上一行p:print打印,通常和-n一同使用s:search,取代 栗子,将示例文件所有的main()变成main(void),显示1到4行,注意如果使用行号表示处理的内容,可以直接在后面接p,a\等命令,如果使用字符串,需要使用//
将字符串和命令隔离开: $ sed -e 's/main()/main(void)/' test_grep|sed -n '1,4p'#includeint main(void){ printf("hello,world!");}
awk
awk既是一门语言也是一个文本流处理工具,这里我们只说作为命令的awk,awk是对文本流以字段为单位进行替换,删除,新增,提取等操作的工具, 默认的字段的分隔符为”tab“或”空格“,可以使用-F来重新指定
$awk [-Ffv]'条件类型1{动作1}条件类型2{动作2}...' filename
-F
表示重新设置分隔符,awk的默认分隔符是tab或空格,不过不指定,是这样的: $ last -n 3jiang pts/0 :0 Mon Sep 19 17:34 still logged in jiang pts/0 :0 Mon Sep 19 16:50 - 16:50 (00:00) jiang pts/0 :0 Mon Sep 19 16:29 - 16:43 (00:14) $ last -n 4|awk '{print $1}'jiangjiangjiangjiang
如果指定了以“M”为分隔符`:
$ last -n 3|awk -F 'M' '{print $1}'jiang pts/0 :0 jiang pts/0 :0 jiang pts/0 :0
awk有三个内建变量来表示处理的行有的数据信息:
NF 每一行拥有的字段总数NR 目前awk所处理的是第几行的数据FS 目前的分隔字符,默认是"空格" 可以使用>, <, >=, <=, ==, != 来做逻辑判断