如何在“ awk”中将2D数组转换为多维数组?

时间:2019-03-07 23:46:54

标签: arrays multidimensional-array awk 2d

我想将2D数组转换为带有“ awk”之类的多维数组,例如

1 2 3 4 5 6 ...
2 4 5 3 6 7 ...
5 3 2 4 5 1 ...
3 5 2 5 5 1 ...
.
.

进入

Array[1]
3 6 ...
2 5 ...
1 4 ...

Array[2]
5 7 ... 
4 6 ...
2 3 ...

.
.
Array[n]

我尝试了不同的方法,但我什至没有找到解决方案。请告知如何实现这一目标...

此外,我从2D数组开始,然后将其转换为我的需要...

'BEGIN {
 for (x = 0; ++x <= 5;)
   for (y = 0; ++y <= 5;)
    A[x][y] = "element:" FS x FS y

 for (i in A) {
   split(i, t, SUBSEP)
     print A[t[1], t[2]]
   }
 }'

但这仅适用于2D ...但是,自从这篇文章发表以来,我得以改善答案

awk '
{ 
  for (i=1; i<=NF; i++)  {
    a[NR,i] = $i
  } 
}
NF>p { p = NF }
END {    
  for(j=1; j<=p; j++) {
    str=a[1,j]
    for(i=2; i<=NR; i++) {
      str=str" "a[i,j];
    }
    print str
  }
 }' f3a.dat > f4.dat ## Transpose

 # Loop for all columns
 awk '{print $1}' f4.dat > f5.dat ## take out a column prior transformation into array

 awk 'ORS=NR%3?FS:RS' f5.dat > f6.dat ## putting column into  array::3=number of elements in row

 awk '
 { 
   for (i=1; i<=NF; i++)  {
     a[NR,i] = $i
   } 
 }
 NF>p { p = NF }
 END {    
   for(j=1; j<=p; j++) {
     str=a[1,j]
     for(i=2; i<=NR; i++) {
       str=str" "a[i,j];
     }
     print str
   }
  }' f6.dat > f7.dat ## transpose

  tac f7.dat > f8.dat ## reverse line order [UNIX command]

我重现了数组[1],但效率不高,因为要转换的实际数组为[72x100000]。

如何将以上内容转换为主循环,然后将每个伪文件f8.dat直接转换为多维数组?

1 个答案:

答案 0 :(得分:0)

不太清楚您要做什么,但是这个awk脚本执行指定的转换:

df.show(30, truncate=False)