如何在linux中处理具有固定宽度列的文件
发布时间:2020-12-13 23:51:35 所属栏目:Linux 来源:网络整理
导读:我想处理下面的文件: 01234000000000000000000+000000000000000000+02586000000000000000000+000000000000000000-12345000000000000000000+000000000000000000-12122000000000000000000+000000000000000000+ 我想将上面的文件转换为: 01234,00000000000000
我想处理下面的文件:
01234000000000000000000+000000000000000000+ 02586000000000000000000+000000000000000000- 12345000000000000000000+000000000000000000- 12122000000000000000000+000000000000000000+ 我想将上面的文件转换为: 01234,000000000000000000+,000000000000000000+ 02586,000000000000000000- 12345,000000000000000000- 12122,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),25)}' file (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |