Linux-shell-AWK

awk处理过程: 依次对每一行进行处理的结果

awk  [-F|-f|-v]  ‘BEGIN{}  //{command1; command2}  END{}’  file  [-F|-f|-v] :-F指定分隔符,-f调用脚本,-v定义变量 var=value BEGIN   初始化代码块,在对每一行进行处理之前,初始化代码,主要是引用全局变量,设置FS分隔符 //           匹配代码块,可以是字符串或正则表达式 END      结尾代码块,在对每一行进行处理之后再执行的代码块,主要是进行最终计算或输出结尾摘要信息   特殊含义: OFS ----输出字段分隔符, 默认也是空格     $0----表示整行所有数据     $1---- 每行第一个字段(列)    NF---- 字段数量(分隔后的列数);$NF最后一列 '{print $NF}'  打印最后一列    NR---- 行号;NR==1代表第一行   'NR==1{print $2}' 打印第一行第二列 ~            匹配字符 !~           不匹配字符 ==         等于 !=           不等于 &&      逻辑与 ||             逻辑或 +            匹配时表示1个或1个以上 1、awk  -F: '{print $1,$3,$6}' OFS="|" /etc/passwd  将/etc/passwd的第一、三、六列内容打印出来,并且以“|”分割 Linux-shell-AWK

2、awk '{print}'  /etc/passwd   ==   awk '{print $0}'  /etc/passwd  

加不加$0,都是打印整行内容

Linux-shell-AWK

3、[root@k8s-master ~]# awk '{print "a"}' /etc/passwd >>ren

passwd有多少行,就会往ren里面写多少行a;每行都是一个a 4、[root@k8s-master ~]# awk -F: 'NR==1{print $1; print $2}'   /etc/passwd  将第一行的以:分割后的字符串,第一个字段、第二个字段分两行显示 Linux-shell-AWK

 

5、awk -F":" '(NR==1){print $1" "$3}' /etc/passwd 等价于 awk -F":" '(NR==1){print $1,$3}' /etc/passwd     每个字段中间会有空格

Linux-shell-AWK

6、每个字符间没有空格,直接相连

[root@k8s-master ~]# awk -F":" '(NR==1){print $1 $3}'  /etc/passwd  

[root@k8s-master ~]# awk -F":" '(NR==1){print $1$3}'  /etc/passwd 

[root@k8s-master ~]# awk -F":" '(NR==1){print $1""$3}'  /etc/passwd 

Linux-shell-AWK

 

 

上一篇:hibernate5(13)注解映射[5]一对一共享主键关联


下一篇:Linux之正则表达式