假设有以下数据:
1,2,3 4,5,6 7,8,9
方法一:使用Bash for循环进行转置
#!/bin/bash
IFS=, transpose="" while read -ra line; do for i in "${!line[@]}"; do transpose[$i]+=${line[$i]}, done done
for data in "${transpose[@]}"; do echo "${data%,}" done
输出:
1,4,7 2,5,8 3,6,9
方法二:使用awk进行转置
我们可以使用awk的内置函数来进行转置:
awk ' BEGIN { FS = ","; OFS = "," } { for (i=1; i<=NF; i++) { a[i,NR] = $i } if (NF>p) p=NF } END { for (j=1; j<=p; j++) { str=a[j,1] for (i=2; i<=NR; i++) { str=str OFS a[j,i]; } print str } }' data.txt
输出:
1,4,7 2,5,8 3,6,9
在此示例中,使用awk进行转置要更快,因为它是用C编写的。而Bash for循环比较慢,因为它是一种解释性语言。