在Unix中为每个记录添加字段到文件的特定位置

时间:2016-06-01 11:57:10

标签: unix awk

我有一个固定宽度的文件,它有两种记录类型10和20.记录类型将在文件的前两个字符中。每列都分配了特定的宽度。

record type-10, record length-45;
record type-20, record length-24

下面是输入文件-test.dat有两个记录,第一个记录记录类型-10和第二个记录记录类型-20:

INPUT:

1023457 lenovo houseno-67panjagutta Hyderabad
206789  Vega   Bangalore

输出:

1023457 lenovo houseno-67panjagutta Hyderabad
206789  Vega   |||||||||||||||||||||Bangalore

我想添加管道到记录类型-20,这样两个记录类型将具有相同的记录长度45.这里记录类型20中缺少地址字段,所以我想在中添加21个管道字符(地址字段)记录类型-20以使两种记录类型具有相同的长度。

1 个答案:

答案 0 :(得分:0)

运行命令

awk -f append.awk test 

append.awk 如下

#! /bin/awk -f
BEGIN{
max=45;
FS=""
}
$1$2 == 20 && length <45{
    FS=" ";
    $0=$0;
    len=length;
    for(i=1; i<=max-len; i++){
        $3="|"$3
    };
    print $0;
    FS="";
    next
} 
1

<强>输出

1023457 lenovo houseno-67panjagutta Hyderabad
206789 Vega ||||||||||||||||||||||||Bangalore