『忘了再学』Shell基础 — 28、AWK中条件表达式说明
1、AWK的条件表达
如下图所示:
2、条件表达式说明
以下练习使用如下文本:
ID Name Python Linux MySQL Java
1 Tangs 88 87 86 85.55
2 Sunwk 99 98 97 96,66
3 Zhubj 77 76 75 74.44
4 Shahs 66 65 64 63.33
(1)BEGIN
BEGIN
是AWK的保留字,是一种特殊的条件类型。
BEGIN
的执行时机是在AWK程序一开始时,尚未读取任何数据之前执行。
BEGIN
后的动作只执行一次,因为当AWK开始从文件中读入数据,BEGIN
的条件就不再成立,所以BEGIN
定义的动作只能被执行一次。
练习:执行命令查看BEGIN
作用:
执行命令:awk 'BEGIN{print "This is BEGIN action"} {printf $2 "\t" $3 "\t" $6 "\t" "\n"}' student.txt
[root@localhost tmp]# awk 'BEGIN{print "This is BEGIN action"} {printf $2 "\t" $3 "\t" $6 "\t" "\n"}' student.txt
This is BEGIN action
Name Python Java
Tangs 88 85.55
Sunwk 99 96.66
Zhubj 77 74.44
Shahs 66 63.33
说明:
- AWK命令只要检测不到完整的单引号不会执行,所以这个命令的换行不用加入
\
,就是一行命令- 上边命令定义了两个动作:
第一个动作使用BEGIN
条件,所以会在读入文件数据前打印“This is BEGIN action”(只会执行一次)
第二个动作会打印文件中的对应文本。
(2)END
END
也是AWK保留字,不过刚好和BEGIN
相反。
END
是在AWK程序处理完所有数据,即将结束时执行。END
后的动作只在程序结束时执行一次。
练习:执行命令查看END
作用:
执行命令:awk 'END{print "This is END action"} {printf $2 "\t" $3 "\t" $6 "\t" "\n"}' student.txt
[root@localhost tmp]# awk 'END{print "This is END action"} {printf $2 "\t" $3 "\t" $6 "\t" "\n"}' student.txt
Name Python Java
Tangs 88 85.55
Sunwk 99 96.66
Zhubj 77 74.44
Shahs 66 63.33
This is END action
说明:在输出结尾输入“This is END action”,这并不是文档本身的内容,而且只会执行一次。
(3)关系运算符
假设我想看看Java绩大于等于80分的学员是谁,就可以这样输入命令:
grep -v "Name" student.txt | awk '$6>=80 {printf $2 "\n"}'
# 判断第六字段(Java成绩)大于等于80分的行,如果判断式成立,则打印第2列(学员名)
[root@localhost tmp]# grep -v "Name" student.txt | awk '$6>=80 {printf $2 "\n"}'
Tangs
Sunwk
grep -v "Name" student.txt
是把标题过滤掉。
(4)说明AWK中条件表达式的执行过程
要先说明一下,虽然AWK是列提取命令,但是也要按行来读入的。
在AWK处理一个文本文件的时候:
- 先判断表达式中有没有
BEGIN
。
如果有,就先执行BEGIN
定义的操作,且执行一次。 - 如果没有
BEGIN
或者BEGIN
定义的动作执行完成之后,会把文本中的第一行数据读入AWK中,
把该行的整行数据赋予$0
变量中,
把该行数据的第一列赋值在$1
变量中,第二列赋值在$2
变量中,以此类推。 - 例如
awk '{printf $2 "\n"}' student.txt
,意思是打印文本中的第二列姓名。
我们先忽略掉条件,流程是:
AWK读取第一行数据(上面一步),然后执行动作输出第二列信息,也就是输出第一行的第二列信息。
然后开始读取第二行数据,然后再执行动作,输出第二行的第二列信息,
然后再读取第三行数据,之后执行动作,输出第三行的第二列信息,
以此类推,基本上就是这样的一个过程。 - 然后在加上条件
awk '$6>=80 {printf $2 "\n"}' student.txt
判断第六列Java的成绩大于80分,才输出。
还是和上边一样,先是AWK读取第一行数据完成之后,就要处理动作了,
但是在处理动作之前,先要判断一下动作前面的条件是否成立,
如果成立,则执行后边的动作。
如果不成立,则不执行跟在后边的动作。
然后在开始读取第二行数据,重复上边的流程,以此类推。
总结一下就是:加入了条件之后,只有条件成立动作才会执行,如果条件不满足,则动作则不运行。 - 最后如果有
END
,则把END
中定义的动作执行一次。
以上就是AWK的执行流程。
(5)AWK中使用正则表达式
如果要想让AWK识别字符串,必须使用//
包含,//
中识别的就是正则表达式规则匹配的字符串。
例如:
# 输出打印Sunwk的成绩
# awk会匹配有Sunwk符号的行,并输出
[root@localhost tmp]# awk '/Sunwk/ {print}' student.txt
2 Sunwk 99 98 97 96.66
注意:这里要注意在AWK中,使用
//
包含的字符串,AWK命令才会查找。也就是说字符串必须用//
包含,AWK命令才能正确识别。
(6)A~B
练习
A~B
是A包含B的意思。
练习:查看Sunwk
用户的Java成绩。
# 匹配第二字段中包含有“Sun”字符,则打印第六字段数据
[root@localhost tmp]# awk '$2 ~ /Sun/ {printf $6 "\n" }' student.txt
96.66
提示:(6)练习的方式,是在某一列中查找是否包含一个字符串。而上面(5)的写法,是在一行数据当中匹配是否包含一个字符串,根据需求灵活使用。
注意:
~
两边有无空格都可以。
拓展练习:
当使用df
命令查看分区使用情况时,如果我只想查看真正的系统分区的使用状况,而不想查看光盘和临时分区的使用状况,则可以执行如下:
# 查询包含有sda+数字的行,并打印第一字段和第五字段
[root@localhost tmp]# df -h | awk '/sda[0-9]/ {printf $1 "\t" $5 "\t" "\n"}'
/dev/sda3 12%
/dev/sda1 15%
『忘了再学』Shell基础 — 28、AWK中条件表达式说明的更多相关文章
- 『忘了再学』Shell基础 — 29、AWK内置变量
目录 1.AWK内置变量 2.练习说明 (1)$n变量练习 (2)FS变量练习 (3)NF变量和NR变量练习 3.总结: 1.AWK内置变量 AWK内置变量如下表: awk内置变量 作用 $0 代表目 ...
- 『忘了再学』Shell基础 — 27、AWK编程的介绍和基本使用
目录 1.AWK介绍 (1)AWK概述 (2)printf格式化输出 (3)printf命令说明 2.AWK的基本使用 (1)AWK命令说明 (2)AWK命令使用 1.AWK介绍 (1)AWK概述 A ...
- 『忘了再学』Shell基础 — 32、Shell中test测试命令详解
目录 1.test测试命令 (1)test命令介绍 (2)test命令使用方式 (3)示例 2.按照文件类型进行判断 3.按照文件权限进行判断 4.两个文件之间进行比较 5.两个整数之间比较 6.字符 ...
- 『忘了再学』Shell基础 — 3、echo命令的介绍与使用
目录 1.echo命令的作用 2.echo命令的基本用法 3.echo命令的-e选项用法 4.echo命令一些特殊用法 (1)输出字符带有字体颜色 (2)输出字符带有背景颜色 在讲Shell脚本之前, ...
- 『忘了再学』Shell基础 — 10、Bash中的特殊符号(二)
提示:本篇文章接上一篇文章,主要说说()小括号和{}大括号的区别与使用. 8.()小括号 ():用于一串命令执行时,()中的命令会在子Shell中运行.(和下面大括号一起说明) 9.{}大括号 {}: ...
- 『忘了再学』Shell基础 — 24、Shell正则表达式的使用
目录 1.正则表达式说明 2.基础正则表达式 3.练习 (1)准备工作 (2)*练习 (3).练习 (4)^和$练习 (5)[]练习 (6)[^]练习 (7)\{n\}练习 (8)\{n,\}练习 ( ...
- 『忘了再学』Shell基础 — 25、扩展正则表达式
目录 1.扩展正则表达式说明 2.练习 (1)+和?练习 (2)|和()练习 3.注意(重点) 1.扩展正则表达式说明 熟悉正则表达式的童鞋应该很疑惑,在其他的语言中是没有扩展正则表达式说法的,在Sh ...
- 『忘了再学』Shell基础 — 30、sed命令的使用
目录 1.sed命令说明 2.行数据操作 (1)查看文件中的数据 (2)删除文件中的数据 (3)向文件中追加数据 (4)向文件中插入数据 (5)修改文件中的多行数据(删除,追加,插入) (6)替换文件 ...
- 『忘了再学』Shell基础 — 1、Shell的介绍
目录 1.Shell的由来 2.Shell的两种执行指令方式 3.什么是Shell脚本 4.Shell 是一种脚本语言 1.Shell的由来 我们比较熟悉Windows系统的图形化界面,对于图形界面来 ...
随机推荐
- EMS恢复禁用邮箱
使用PowerShell命令恢复禁用邮箱 键入以下命令: [PS] C:\Windows\system32>Get-MailboxDatabase | Get-MailboxStatistics ...
- CommonsCollection4反序列化链学习
CommonsCollection4 1.前置知识 由于cc4没有新的知识点,主要是用cc2,然后稍微cc3结合了,所以我们可以看ysoserial源码,自己尝试构造一下,把cc2通过获取Invoke ...
- MFC---视图和窗口
视类窗口 视类窗口是指程序运行后,显示信息的那一部分.对应的类是CTestOneView(TestOne表示项目名称)类,CTestOneView类是派生于CView类,而CView类又派生于CWnd ...
- mysql server_id的用途(主从等结构中)
前言 我们都知道MySQL用server-id来唯一的标识某个数据库实例,并在链式或双主复制结构中用它来避免sql语句的无限循环.5.7需要同时设置server_id参数,8.0开始server_id ...
- C++STL 中的数值算法(iota、accumulate、adjacent_difference、inner_product、partial_sum)
以下算法均包含在头文件 numeric 中 ##1.iota 该函数可以把一个范围内的序列从给定的初始值开始累加 先看用法. 例: 假设我需要一个长度为10,从5开始递增的序列 vector<i ...
- 初识tomcat和servlet
web相关概念回顾 软件架构 C/S:客户端/服务器端 B/S:浏览器/服务器端 资源分类 静态资源:所有用户访问后,得到的结果都是一样的,称为静态资源.静态资源可以直接被浏览器解析 如: html, ...
- pt-osc又又出现死锁了
今天使用pt-osc修改mysql表结构,又出现死锁了,老大让尽量解决这个问题,我们先分析一下pt-osc容易出现死锁的原因,再来解决这个问题. 根据pt-osc打印的日志,可以看到pt-osc执行原 ...
- Java语言学习day05--7月2日
今日内容介绍1.引用类型变量的创建及使用2.流程控制语句之选择语句 ###01创建引用类型变量公式 * A: 创建引用类型变量公式 * a: 我们要学的Scanner类是属于引用数据类型,我们先了解下 ...
- Python技能树及CSDN MarkDown编辑器测评
测评目录 python技能树测评 python技能树是什么 python技能树长什么样 如何学习python技能树 python技能树可能需要的改进 对python技能树的总结 CSDN MarkDo ...
- python代码统计核酸检测结果截图
#QQ:502440275@qq.com#本截图适合安康码截图,如需其他地区截图统计,可与我QQ或QQ邮箱联系#1.在当前文件夹下创建imgs文件夹用于存放图片,图片格式.jpg#2.在当前文件夹下创 ...