我想处理下面的文件:
01234000000000000000000+000000000000000000+
02586000000000000000000+000000000000000000-
12345000000000000000000+000000000000000000-
12122000000000000000000+000000000000000000+
我想将上面的文件转换为:
01234,000000000000000000+,000000000000000000+
02586,000000000000000000+,000000000000000000-
12345,000000000000000000+,000000000000000000-
12122,000000000000000000+,000000000000000000+
输入文件分别具有固定宽度列5,19,19.
我想解决使用linux命令.
我尝试下面的命令,但它不工作:(
awk 'BEGIN{FIELDWIDTHS="5 19 19";OFS=",";}{$1="$1,$2,$3"}' data.txt
在ubuntu 14.04 LTS桌面操作系统上执行上述命令,输出结果为空(空白).
解决方法:
虽然您忘了{print},但您的尝试非常接近:
awk 'BEGIN{FIELDWIDTHS="5 19 19";OFS=","}{$1=$1}1' file
{$1 = $1}将第一个字段分配给自己,这足以使awk“触摸”每个记录.我用过速记1,这是最短的真实情况.默认操作是{print}.
请注意,FIELDWIDTHS是一个GNU awk扩展,因此如果您使用的是其他版本,则必须采用不同的方法.例如:
awk 'BEGIN{OFS=","}{print substr($0,1,5),substr($0,6,19),substr($0,25)}' file
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。