如何使用命令行工具将制表符分隔的表格转换为标记部分?

如何使用命令行工具将制表符分隔的表格转换为标记部分?

也就是说,转动这个:

Column_A   Column_B   Column_C
--------   --------   --------
value-1a   value-1b   value-1c
value-2a   value-2b   value-2c

进入这个:

Column_A: value-1a
Column_B: value-1b
Column_C: value-1c

Column_A: value-2a
Column_B: value-2b
Column_C: value-2c

答案1

如果上表位于名为的文件中table

$ awk 'NR==1 { for (i=1;i<=NF;i++) header[i]=$i }
       NR>2  { for (i=1;i<=NF;i++) print header[i] ": " $i
               print ""}' table

标头收集在第一行。第二行被跳过。其余行打印如图所示。

我认为它不是很优雅,但可以完成工作。

答案2

$ cat tst.awk
BEGIN { OFS="\n"; ORS="\n\n" }
NR == 1 { split($0,tags) }
NR > 2 {
    for (i=1; i<=NF; i++) {
        printf "%s: %s%s", tags[i], $i, (i<NF ? OFS : ORS)
    }
}

$ awk -f tst.awk file
Column_A: value-1a
Column_B: value-1b
Column_C: value-1c

Column_A: value-2a
Column_B: value-2b
Column_C: value-2c

相关内容