首页 > 编程知识 正文

grepawk效率,grep和awk

时间:2023-05-05 00:27:26 阅读:13022 作者:185

Linux三剑客(grep、sed、awk )详情

前言:本文主要介绍Linux中最重要的三条命令。 他们在业界被称为“三剑客”。 它们分别是awk、sed、grep。 这三个侧的功能不同,grep擅长搜索,sed擅长行和替换,awk擅长排队。 分别介绍三个主要选项和应用实例。

一、文本过滤工具grep(egrep )。

grep [OPTIONS] PATTERN [FILE.]

1.1、关键选项

--color=auto对匹配文本进行着色显示

-v表示pattern不匹配的行

-忽略I字符的大小写

-n显示匹配的行号

-c统计匹配的行数

-o仅显示匹配的字符串

-q静音模式,不输出任何内容

-A # after,后#行

-B # before,第一个#行

-C # context,前后各#行

-e实现多个选项之间的逻辑or关系grepe‘cat’- e‘dog’file

匹配整个-w单词

-E使用ERE,相当于egrep

-F相当于fgrep,不支持正则表达式

1.2、grep应用实例

在文件中搜索包含根的行grep -n root /etc/passwd

二、流编辑器---强大的替换工具sed

sed是流编辑器,一次处理一行内容。 处理时,将当前处理的行存储在临时缓冲区中,称为“阵列空间”(pattern space ),然后用sed命令处理缓冲区中的内容,处理完成后将缓冲区的内容发送到屏幕。 然后读取下行,执行以下循环。 如果不使用类似' d '的特殊命令,则模式区域在两个循环之间为空,但保留区域不为空。 这样重复到文件的末尾。 除非使用重定向的存储输出,否则文件内容不会改变。

sed [ option ] . ' script ' input file

2.1、关键选项

-n不在画面上输出模式空间的内容。 即,不自动打印

-e多点编辑

-f/PATH/SCRIPT_FILE:从指定文件读取编辑脚本

-r支持使用扩展正则表达式

-i直接编辑文件

-备份-i.bak文件并在原始位置编辑

2.2、脚本分隔符

不给地址:处理全文

单地址:

#:指定行,$ :最后一行

/pattern/

地址范围:

#,#

#,#

/pat1//pat2/

` #,/pat1/

~ :步进

1~2奇数行

2~2偶数行

2.3、编辑命令:

删除d图案区域匹配的行,立即启用以下循环

p打印当前模式空间的内容并添加到默认输出后

a []text1在指定行之后添加文本,n并支持使用添加多行

I在[]文本行之前插入文本

c []文本替换一行或多行文本

与w /path/somefile保存模式匹配的行保存在指定文件中

r /path/somefile将指定文件中的文本导入架构空间中的匹配行后

=打印模式空间中行的行号

! 模式空间中一致行的反转处理

s//:查找替换,支持使用其他分隔符,s@@@,s##替换标记:

g行中的全局替换

p显示替换成功的行

w /PATH/TO/SOMEFILE将成功替换的行保存到文件中

2.4、应用实例

打印文件的第二行中的sed -n 2p /etc/passwd

三、报表生成器awk ---列抽神器

awk [ options ] '程序文件…

程序: pattern { action statements; }pattern部分确定操作语句何时触发和触发事件

BEGIN,END

操作语句处理数据,并将其放入{}中指定

打印,打印

3.1、关键选项

-F表示输入时使用的字段分隔符

-v var=value自定义变量

运行awk时,以分隔符分隔的字段(域)将1、1、2、 n称为域id,n称为域id,0称为所有域。

如果省略action,则缺省情况下执行print $0操作。

3.2、变量

FS:输入字段分隔符;

OFS :输出字段分隔符;

RS :输入记录分隔符;

ORS :输出记录分隔符;

NF :字段数;

NR:记录号;

NFR:各文件分别计数,记录号。

FILENAME:当前文件名;

ARGC:命令行的参数;

ARGV:数组,保存的是命令行所给定的各参数。注意:以上都是内置变量,在引用时不需要前面加$,每新建一个变量,都需要加个-v,与变量名之间有无空格都可以,变量可以在引用之后再声明,但那一行的输出会输出空行。

3.3、printf命令

printf “FORMAT” , item1, item2, ... 不会自动换行,FORMAT中需要分别为后面每个item指定格式符。

格式符No.

item

表现形式

1

%c

显示字符的ASCII码

2

%d, %i

显示十进制整数

3

%e, %E

显示科学计数法数值

4

%f

显示为浮点数

5

%g, %G

以科学计数法或浮点形式显示数值

6

%s

显示字符串

7

%u

无符号整数

8

%%

显示%自身操作符No.

格式符

item表现形式1

#[.#]

第一个数字控制显示的宽度;第二个#表示小数点后精度,%3.1f

2

-

左对齐(默认右对齐) %-15s

3

+

显示数值的正负符号 %+d操作符算术操作符:x+y, x-y, x*y, x/y, x^y, x%y-x: 转换为负数

+x: 转换为数值

比较操作符:==, !=, >, >=,

模式匹配符:~:左边是否和右边匹配包含 !~:是否不匹配

逻辑操作符:与&&,或||,非!

函数调用:function_name(argu1, argu2, ...)

条件表达式(三目表达式):selector?if-true-expression:if-false-expressionPATTERN:根据pattern条件,过滤匹配的行,再做处理如果未指定:空模式,匹配每一行

/regular expression/:仅处理能够模式匹配到的行,需要用/ /括起来

relational expression: 关系表达式,结果为“真”才会被处理

line ranges:行范围 startline,endline:/pat1/,/pat2/不支持直接给出数字格式

BEGIN/END模式

awk控制语句{ statements;… } 组合语句

if(condition) {statements;…}

if(condition) {statements;…} else {statements;…}

while(conditon) {statments;…}

do {statements;…} while(condition)

for(expr1;expr2;expr3) {statements;…}

break

continue

delete array[index]

delete array

exit

3.4、应用实例

打印文件第一列(文件分隔符为‘:’)awk -F ':' '{print $1}' /etc/passwd

四、参考文献

标签:grep,sed,awk,statements,分隔符,匹配,三剑客

来源: https://blog.csdn.net/gsjthxy/article/details/106985813

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。