我想将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直接转换为多维数组?
答案 0 :(得分:0)
不太清楚您要做什么,但是这个awk脚本执行指定的转换:
df.show(30, truncate=False)