首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将字段添加到Unix中每个记录的文件的特定位置

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

Stack Overflow用户
提问于 2016-06-01 11:57:10
回答 1查看 394关注 0票数 0

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

代码语言:javascript
复制
record type-10, record length-45;
record type-20, record length-24

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

输入:

代码语言:javascript
复制
1023457 lenovo houseno-67panjagutta Hyderabad
206789  Vega   Bangalore

输出:

代码语言:javascript
复制
1023457 lenovo houseno-67panjagutta Hyderabad
206789  Vega   |||||||||||||||||||||Bangalore

我想要添加管道到记录类型-20,以便两种记录类型都有相同的记录长度45。在记录类型20中缺少地址字段,因此我希望在记录类型-20中添加21个管道字符(地址字段),以使这两个记录类型具有相同的长度。

EN

回答 1

Stack Overflow用户

发布于 2016-06-01 12:28:47

运行命令

代码语言:javascript
复制
awk -f append.awk test 

append.awk如下

代码语言:javascript
复制
#! /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

输出

代码语言:javascript
复制
1023457 lenovo houseno-67panjagutta Hyderabad
206789 Vega ||||||||||||||||||||||||Bangalore
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37567976

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档