一、三元运算符
- 还记的之前学习编程语言时的 " if ... else ... " 结构吗?其实我们使用三元运算符就可以代替其功能。
- 三元运算符的形式1:[ 结果 = 条件 ? 结果1:结果2 ]
- 三元运算符的形式2:[ 条件 ? 表达式1 : 表达式2 ]
- 代码示例,如下:
(1) if ... else ... 形式
etl@bejedw09:/home/etl/cya> cat file
student1 98
student2 89
student3 93
student4 78
student5 91
student6 96
etl@bejedw09:/home/etl/cya> awk '{if($2>=90){print $1,"perfect"} \
else { print $1,"come on !!!" } }' file
student1 perfect
student2 come on !!!
student1 perfect
student2 come on !!!
student1 perfect
student1 perfect
(2)三元运算符示例1
etl@bejedw09:/home/etl/cya> awk '{type=$2>=90? "perfect":"come on !!!";\
print $1 , type}' file
student1 perfect
student2 come on !!!
student1 perfect
student2 come on !!!
student1 perfect
student1 perfect
(3)三元运算符示例2
etl@bejedw09:/home/etl/cya> awk '{$2=90? a++:b++ } END{print a , b}' file
4 2
#可以使用三元运算符统计个数,成绩大于等于90分的学生有4个,小于90的也有2个
二、打印奇偶行
在 Linux 环境中如果想要打印文件的奇偶行,方法实在是太多了,先来看 awk 是如何实现的
etl@bejedw09:/home/etl/cya> awk 'NR%2==0{print $0}' file
student2 89
student4 78
student6 96
etl@bejedw09:/home/etl/cya> awk 'NR%2!=0{print $0}' file
student1 98
student3 93
student5 91
#awk打印文件的奇偶行
再来看看 sed 又是如何实现的
etl@bejedw09:/home/etl/cya> sed -n '2~2p' file
student2 89
student4 78
student6 96
etl@bejedw09:/home/etl/cya> sed -n '1~2p' file
student1 98
student3 93
student5 91
#sed打印文件的奇偶行
上面的两种 awk 和 sed 打印文件奇偶行的方式已经是非常经典的了,这里再用 awk 的另外一种方式实现打印文件奇偶行
etl@bejedw09:/home/etl/cya> awk 'i=!i' file
student1 98
student3 93
student5 91
etl@bejedw09:/home/etl/cya> awk '!(i=!i)' file
student2 89
student4 78
student6 96
#上面这两条命令是如何实现打印文件奇偶行的哪?看下面的文字解释和代码示例就晓得了^_^
#提示1:在 awk 中,如果省略了模式对应的动作,当前行满足模式时,默认打印整行,即
# { print $0 };
代码示例1:
etl@bejedw09:/home/etl/cya> awk '1' file
student1 98
student2 89
student3 93
student4 78
student5 91
student6 96
etl@bejedw09:/home/etl/cya> awk '0' file
etl@bejedw09:/home/etl/cya>
#提示2:当 awk 开始处理第一行时,变量 i 被初始化,变量 i 在被初始化时值为 "空",
# 在 awk 中,数字0或者 "空字符串"表示 "假",非0或非空字符串表示"真" 所以
# 可以认定上述模式为假,那就是模式不成立所以不需要执行对应的动作,但是i直接取
# 反了,对假取反就是真,将取反后的值又赋值给了变量i,所以此刻执行print {$0}
# 看下面的命令,我们可以追踪变量 i 的值,再根据 "代码示例1" ,屏幕前这么cute、
# 这么clever的读者一定明明白白的了吧
代码示例2:
etl@bejedw09:/home/etl/cya> awk '{ i=!i; print i }' file
1
0
1
0
1
0
- 结尾
本文就打印文件奇偶行的问题花费的笔墨最多,而且介绍了三种方法来实现,要知道实际开发中打印文件奇偶行并不常见,至少我工作到现在,几乎每天都要处理文本,还没有碰到过打印文件奇偶行的需求,那么我们为什么还要学习哪?我也想过这个问题,上过高中的同学都有过这么的经历,最后高考的题都有固定的题型,我们在平时的学习中做练习册的时候会发现有些题型怪怪的,根本不符合高考的出题规范,那么这类题的意义是什么哪?高中数学老师的解释是:“这类题型高考不会出,可是这类题你们也要做,因为这可以让你们更好的理解这个知识点”,同样的,在这里它就可以帮我们更好的理解 awk 这个命令,如果你把第三种打印文件奇偶行的方式搞的很明白的话,你就会发现,你更加了解 awk 包括它的一些默认处理,你和 awk 的距离就拉近了,以后遇到文本格式化问题使用 awk 就会变得得心应手^_^