1.grep查找
结合正则表达式功能十分强大
grep [选项] 要查找内容(可用正则表达式) 在该文件中查找
常用选项:
-c 只显示匹配的行数
-h 查询多文件时不显示文件名
-I 不区分大小写
-l 查询多文件时,只输出匹配文件的文件名
-n 显示匹配的行及行号
-v 显示不包含匹配文本的所有行
2.sed编辑
三种使用方法:
1、在shell命令行调用 格式:sed [选项] ‘command’ 输入文件
command要加单引号,也允许加双引号
2、将sed命令插入脚本后,通过sed命令调用 格式:sed [选项] -f sed脚本文件 输入文件
3、将sed命令插入脚本后,执行该脚本 格式:./sed脚本文件 输入文件
常用选项:
-e 多重编辑
-i 直接编辑,修改文件内容
-f
-n 安静模式,只显示处理的那一行,而不显示来自stdin输入的内容
动作:
a 新增至下一行,a后面接字符串
c 取代 sed '/test/c RRRR' test.txt
d 删除
i 插入至上一行,i后面接字符串
p 打印
s 取代
3.awk文本分析并处理
相对于sed常常用于处理一行,awk更倾向于处理一行中的一个一个字段
3.1 三种使用方式
1、在shell命令行调用 格式:awk [-F 域分隔符] ‘command’ 输入文件
2、将awk命令插入脚本后,通过awk命令调用 格式:awk -f awk脚本文件 输入文件
3、将awk命令插入脚本后,执行该脚本 #!/bin/awk
3.2 awk的处理流程
1、读取第一行,将第一行信息一次填入变量$0 $1 $2..
2、依据条件限制,执行动作
3、接下来依次处理下一行
3.3 awk的if判断
BEGIN
END
变量:
NF 代表每一行的$0的字段总数
NR 代表目前awk所处理的是第几行数据
FS 代表目标分割符,默认是空格
RS 记录分隔符,(默认是\n,一行也就是一条记录),当RS=""时,以多个换行符来分割记录
且当RS=""时,换行符,tab,空格都为默认分隔符
seq 9 | sed 'H;g' | awk -v RS='' '{for(i=1;i<=NF;i++)printf("%dx%d=%d%s", i, NR, i*NR, i==NR?"\n":"\t")}',这条命令打印99乘法表