linux awk文本
目录
一、awk概念
二、awk的工作过程
三、awk字符
四、内置变量
五、getline
六、awk的精准筛选
七、例子演示
八、实验演示
一、awk概念
1.概念:awk 是一个功能强大的编辑工具,逐行读取输入文本,主要作用于文件内容,AWK信息的读入也是逐行指定的匹配模式进行查找,
对符合条件的内容进行格式化输出或者过滤处理。
2.分隔符:默认是空格,多个空格会压缩一个,可用-F指定分割符
3.awk执行过程:1、按照命令找指定的行 2、找到的行 打印,操作 awk默认的操作就是打印
4.awk优点:可以在无交互的情况下自动化完成文本操作
二、awk的工作过程
1.有BEGIN{action;..}优先执行
2.从(stdin)中读取内容,执行pattern{action;..}读取文件内容(没有pattern执行print内容)
3.执行END{action;..}内容

三、awk字符
1.-F “分隔符” 指明输入时用到的字段分隔符,默认的分隔符是若干个连续空白符
2.-v变量赋值
3.{ }外指定条件,{ }内指定操作。
4.用逗号指定连续的行,用 || 指定不连续的行。&&表示”且“。
5.默认为空格或制表位。与"-F"作用相同 用-F可以不加单引号 -F:,用FS必须用=""
例子演示:
1.-F指定分隔符

2.-v赋值为:,每次出现:就空格

3.{}外条件是数量为0打印,{}里操作是打印

4.,为间隔符||为且&&为或


5.FS定义分割符

四、内置变量
内置变量,不能用双引号括起来,不然系统会把它当成字符串。
NR: 当前处理的行的行号(序数)
NF: 当前处理的行的字段个数。$NF代表最后一个字段
FS: 列分割符。指定每行文本的字段分隔符,输入内容的分隔符
默认为空格或制表位。与"-F"作用相同 用-F可以不加单引号 -F:,用FS必须用=""
$0: 当前处理的行的整行内容 打印所有
$n: 当前处理行的第n个字段(第n列)
OFS:输出内容的列分隔符
FILENAME:被处理的文件名
RS: 行分隔符。awk从文件中读取资料时,
将根据RS的定义把资料切割成许多条记录,而awk一次仅读入一条记录进行处理。预设值是"\n"
1.$0$1(在里面是$0打印所有$1打印一列),在外面0不打印,1打印



2.NR输出统计行号

3.展示行号以及内容

4.打印指定行号内容

5.范围打印

6.打印不相连的行

7.正则表达式的范围打印

8.偶数打印

9.奇数打印

10.BEGIN计算

11.幂运算

五、getline
1.当getline左右无重定向符号(“<”,">")或者管道符号(“|”)时,awk首先读取的是第一行,而getline获取的是光标跳转至下一行的内容(也就是第二行)。
2.当getline左右有管道符号或重定向符时,getline则作用定向输入文件,由于文件是刚打开,并没有被awk读入一行,而只是getline读入,所以getline返回的是文件的第一行,而不是跳转至一行输入
使用getline偶数打印

使用getline奇数打印

使用getline将1.txt传给2.txt

将1.txt内容传给2.txt展示出来

六、awk的精准筛选
$n(> < ==): 用于对比数值
$n~"字符串": 代表第n个字段包含某个字符串
$n!~"字符串": 代表第n个字段不包含某个字符串
$n=="字符串": 代表第n个字段为某个字符串
$n!="字符串": 代表第n个字段不为某个字符串
$NF: 代表最后一个字段
1.输出有bash,并且输出第一列和第7列

2.输出第七个字段不包含“nologin”所在行的第一个字段和最后一个字段

七、例子演示
1.过滤打印


2.行号加1递归

3.过滤passwd展示前4行的第一列

4.替换:换为+

5.以:为分隔符换行输出

6.打印uid大于1000的用户信息

7.使用if判断用户信息

8.三元表达式,?相当于then,:相当于else

9.awk中的数组形成遍历

八、实验演示
1.简单的日志分割

2.提取host.txt主机名后再放回host.txt文件

3.统计磁盘可用容量

4.统计/etc下文件总大小

5.CPU使用率

6.统计内存


浙公网安备 33010602011771号