首页 > 其他 > 详细

awkOFS问题

时间:2017-06-20 16:54:18      阅读:214      评论:0      收藏:0      [点我收藏+]

awk改变了OFS,$0却没变化
一个文件1.txt,内容如下

a
b
c
d
e

  


目的把列变行,输出为: a b c d e

脚本如下:

awk ‘BEGIN{RS="";FS="\n";OFS=" "}{print }‘ test
a
b
c
d
e

  


理论上应该实现我们想要的 a b c d e

问题出在这里

Understanding $0


It is important to remember that $0 is the full record, exactly as it was read from the input. This includes any leading or trailing whitespace, and the exact whitespace (or other characters) that separate the fields.

It is a not-uncommon error to try to change the field separators in a record simply by setting FS and OFS, and then expecting a plain ‘print’ or ‘print $0’ to print the modified record.

But this does not work, since nothing was done to change the record itself. Instead, you must force the record to be rebuilt, typically with a statement such as ‘$1 = $1’, as described earlier.

 

 

 

 

 


google翻译:

重要的是要记住,$ 0是完整的记录,与从输入读取完全一样。 这包括任何前导或尾随空白以及分隔字段的确切空格(或其他字符)。
尝试通过设置FS和OFS来更改记录中的字段分隔符是常见的错误,然后期待一个普通的“打印”或“打印$ 0”来打印修改的记录。
但是这并不奏效,因为没有改变记录本身。 相反,您必须强制重新创建记录,通常使用诸如“$ 1 = $ 1”的语句,如前所述。

It works !

quke@Raphaelqu:/tmp$ awk ‘BEGIN{RS="";FS="\n";OFS=" "}{$1=$1;print}‘ 1.txt
a b c d e f g

详情参考:
http://www.gnu.org/software/gawk/manual/html_node/Changing-Fields.html

awkOFS问题

原文:http://www.cnblogs.com/irockcode/p/7055016.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!