awk的默认分割符是空格,awk的分隔符还分为两种,“输入分隔符” 和 “输出分隔符” 。
输入分隔符,英文原文为field separator,此处简称为FS 输入分割符,默认是空白字符(即空格),awk默认以空白字符为分隔符对每一行进行分割。 输出分割符,英文原文为output field separator,此处简称为OFS
awk将每行分割后,输出在屏幕上的时候,以什么字符作为分隔符,awk默认的输出分割符也是空格。
输入分隔符当awk逐行处理文本的时候,以输入分隔符为准,将文本切成多个片段,默认使用空格,但是,如果一段文字中没有空格,我们可以指定以特定的文字或符号作为输入分割符,如下指定使用"#"作为输入分隔符。
[root@node1 awkdir]# cat awktxt2 abc#123#efg#hij 9ijdd#sdf#asdf#bnm
使用-F 选项,指定使用#号作为输入分隔符
[root@node1 awkdir]# awk -F# '{print $1,$2}' awktxt2
abc 123
9ijdd sdf
内置变量方式指定分隔符
除了使用 -F 选项指定输入分隔符,还能够通过设置内部变量的方式,指定awk的输入分隔符,awk内置变量FS可以用于指定输入分隔符,但是在使用变量时,需要使用-v选项,用于指定对应的变量,比如 -v FS=’#’
[root@node1 awkdir]# awk -v FS='#' '{print $1,$2}' awktxt2
abc 123
9ijdd sdf
回顾:这个时候就是使用awk中的选项-F。awk的语法如下: awk [options] ‘Pattern{Action}’ file
输出分隔符当awk为我们输出每一列的时候,会使用空格隔开每一列,空格就是awk的默认的输出分隔符,下图中红线标注的空格部分,就是awk的默认的输出分隔符。
输出分割符:当要对处理完的文本进行输出的时候,以什么文本或符号作为分隔符。
使用awk的内置变量OFS来设定awk的输出分隔符。
[root@node1 awkdir]# cat awktxt zaishu mysql qq xasdf xxx sdfsadf dd xx
[root@node1 awkdir]# awk '{print $1,$2}' awktxt
zaishu mysql
xasdf xxx
dd xx
使用内置变量作为输出分隔符
[root@node1 awkdir]# awk -v OFS='+++' '{print $1,$2}' awktxt
zaishu+++mysql
xasdf+++xxx
dd+++xx
同时指定输入分隔符和输出分割符
[root@node1 awkdir]# cat awktxt2
abc#123#efg#hij
9ijdd#sdf#asdf#bnm
[root@node1 awkdir]# awk -v FS='#' -v OFS='+++' '{print $1,$2}' awktxt2
abc+++123
9ijdd+++sdf
多列合并输出
输出的时候,要让两列合并一起显示,蓝线之上使用默认的输出分隔符进行了分隔,而蓝线之下的两种方法未使用输出分隔符进行分隔,而是将两列合在一起。
上图中的示例在语法上的区别就是,一个有"逗号",一个没有"逗号"。
awk '{print $1 $2}' 表示每行分割后,将第一列(第一个字段)和第二列(第二个字段)连接在一起输出。
awk '{print $1,$2}' 表示每行分割后,将第一列(第一个字段)和第二列(第二个字段)以输出分隔符隔开后显示。



