awk中RS,ORS,FS,OFS区别分析(实例讲解)

发布时间:2020-07-14编辑:脚本学堂
本文介绍下awk中RS,ORS,FS,OFS的区别,通过具体的例子进行分析,有需要的朋友,可以参考下。

一,RS与ORS
1,RS是记录分隔符,默认的分隔符是n,具体用法看下
 

复制代码 代码示例:
[root@krlcgcms01 mytest]# cat test1     //测试文件 
 111 222 
 333 444 
 555 666 

2,RS默认分割符n
 

复制代码 代码示例:
[root@krlcgcms01 mytest]# linuxjishu/13830.html target=_blank class=infotextkey>awk '{print $0}' test1  //awk 'BEGIN{RS="n"}{print $0}' test1 这二个是一样的 
111 222 
333 444 
555 666 
 

其实你可以把上面test1文件里的内容理解为,111 222n333 444n555 6666,利用n进行分割。看下一个例子

3,自定义RS分割符
 

复制代码 代码示例:
[root@localhost test]$ echo "111 222|333 444|555 666"|awk 'BEGIN{RS="|"}{print $0,RT}' 
 111 222 | 
 333 444 | 
 555 666 
 

结合上面一个例子,就很容易理解RS的用法了。

4,RS也可能是正则表达式
 

复制代码 代码示例:
[root@localhost test]$ echo "111 222a333 444b555 666"|awk 'BEGIN{RS="[a-z]+"}{print $1,RS,RT}' 
 111 [a-z]+ a 
 333 [a-z]+ b 
 555 [a-z]+ 
 

从例3和例4,我们可以发现一点,当RT是利用RS匹配出来的内容。如果RS是某个固定的值时,RT就是RS的内容。

5,RS为空时
 

复制代码 代码示例:
[root@localhost test]$ cat -n test2 
 1  111 222 
 2 
 3  333 444 
 4  333 444 
 5 
 6 
 7  555 666 
[root@localhost test]$ awk 'BEGIN{RS=""}{print $0}' test2 
111 222 
333 444 
333 444 
555 666 
[root@localhost test]$ awk 'BEGIN{RS="";}{print "<",$0,">"}' test2  //这个例子看着比较明显 
< 111 222 > 
< 333 444     //这一行和下面一行,是一行 
333 444 > 
< 555 666 >

从这个例子,可以看出当RS为空时,awk会自动以多行来做为分割符。