首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用awk将一条记录拆分为多个字段

使用awk将一条记录拆分为多个字段
EN

Stack Overflow用户
提问于 2017-05-04 19:55:24
回答 2查看 656关注 0票数 0

我有一个文件,其中的记录不用任何分隔符分隔。下面分享了一个示例:

XXXXXYYYYZZZ

XXXXXYYYYZZZ

XXXXXYYYYZZZ

XXXXXYYYYZZZ

XXXXXYYYYZZZ

我已经得到了文件的DDL,即字段1位于位置1-5,字段2位于位置6-9,字段3位于位置10-12

如何使用awk命令打印以下输出?

field1、field2、field3

XXXXX、YYYY、ZZZ

XXXXX、YYYY、ZZZ

XXXXX、YYYY、ZZZ

XXXXX、YYYY、ZZZ

XXXXX、YYYY、ZZZ

EN

回答 2

Stack Overflow用户

发布于 2017-05-04 20:16:49

在GNU awk中使用FIELDWIDTHS

代码语言:javascript
运行
复制
$ awk '
BEGIN {
    FIELDWIDTHS="5 4 3"                 # here you state the field widths
    OFS=","                             # output field separator
    print "field1","field2","field3" }  # print header in BEGIN
{
    print $1,$2,$3 }                    # print 3 first fields, you could also:
' file                                  # {$1=$1; print} or even:
field1,field2,field3                    # {$1=$1}1
XXXXX,YYYY,ZZZ
XXXXX,YYYY,ZZZ
XXXXX,YYYY,ZZZ
XXXXX,YYYY,ZZZ
XXXXX,YYYY,ZZZ

如果您没有GNU awk,请使用f1=substr($0,1,5);f2=substr($0,6,4)...print f1,f2,f3

编辑:

代码语言:javascript
运行
复制
$ awk '
BEGIN {
    OFS=","
    print "field1","field2","field3" }
{
    f1=substr($0,1,5)
    f2=substr($0,6,4)
    f3=substr($0,10,3)
    print f1,f2,f3 }
' file

后者作为插入了;的一行程序:

代码语言:javascript
运行
复制
$ awk 'BEGIN {OFS=","; print "field1","field2","field3"}{f1=substr($0,1,5); f2=substr($0,6,4); f3=substr($0,10,3); print f1,f2,f3}' file

前者作为一行程序:

代码语言:javascript
运行
复制
$ awk 'BEGIN{FIELDWIDTHS="5 4 3"; OFS=","; print "field1","field2","field3"}{print $1,$2,$3}' file
票数 1
EN

Stack Overflow用户

发布于 2020-09-28 17:48:17

这可能适用于您(GNU sed):

代码语言:javascript
运行
复制
sed -e '1i\field1,field2,field3' -e 's/[^,]/,&/6;s//,&/10' file
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43782220

复制
相关文章

相似问题

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