[英]parsing of files using AWK with field-separators - does not parse correctly
[英]Using record separators in awk
我有
$ cat awktestf
a++
b++
c++
我在做,我得到
cat awktestf | awk 'BEGIN { RS="++" ; OFS="@"; ORS="()" } { print $0 } END {print "I am done" }'
a()
b()
c()
()I am done()abc@abc:~$
我的问题是,为什么最后我要得到一个额外的()?
即使这样也不起作用:
$ echo 'a++
> b++
> c++' | awk 'BEGIN { RS="++" ; OFS="@"; ORS="()" } { print $0 } END {print "I am done" }'
a()
b()
c()
()I am done()abc@abc:~$
ORS
附加到每个输出记录的末尾。 因此,您的“我完成了”以()
结尾。
第一次误解了这个问题。
这个
a++
b++
c++
转换为
a++\nb++\nc++\n
使用RS
拆分成记录后,您将获得这些记录
打印它们时,每个记录都以ORS
()
终止。
a()\nb()\nc()\n()
您添加了“我完成了”
a()\nb()\nc()\n()I am done()
因此,这显示为
a()
b()
c()
()I am done()
(由于最后一行不以换行符结尾,因此提示显示在同一行上)
文件末尾可能有一个空白行。
由于OFS
设置为()
,因此它将在打印到输出的每一行之后打印。 只需从输入文件中删除空白行即可。
旁注:您不必先cat
文件,再通过管道传输到awk。 只需使用awk
:
awk ' .... ' file
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.