也就是说,转动这个:
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