我可能会以错误的方式解决这个问题,但我正在尝试在循环中定义和填充数组。
for i = 0,39 do begin
xx = long(findgen(n+1l)*sx + line1x[i])
sz = size(xx)
arrayname = 'line' + strtrim(i,2)
arrayname = findgen(3,sz[1])
arrayname[0,*] = xx
arrayname[1,*] = yy
arrayname[2,*] = vertline
endfor
这显然不起作用,但有没有办法使用'line'+ strtrim(i,2)定义的字符串在每次迭代时创建并填充一个新数组?在这种情况下,我有40个名为line0 ... 39的数组。这里的困难部分是sz [1]变化,所以我不能简单地定义一个大数组来保存所有内容。
答案 0 :(得分:3)
在idl 8.0或更高版本中,您可以使用HASH
数据类型。
您的代码如下所示:
array_dict = hash()
for ii = 0,39 do begin
xx = long(findgen(n+1l)*sx + line1x[ii])
sz = size(xx)
arrayname = 'line' + string(1, FORMAT='(i02)')
array = findgen(3,sz[1])
array[0,*] = xx
array[1,*] = yy
array[2,*] = vertline
array_dict[arrayname] = array
endfor
您现在可以按名称访问数组:
line = array_dict['line01']
答案 1 :(得分:2)
嗯,如果你想要一个肮脏的黑客(并且不需要它在未经许可的虚拟机安装上运行),总会有execute
函数。
但您是否考虑过声明一维指针数组,其中每个元素都指向3个sz子阵列中的一个?这给你一个大阵列的一些好处, 没有所有子阵列的约束必须具有相同的形状。 它可能看起来像这样......
ptrs=ptrarray(40) ; Allocate an array of 40 pointers, initialized to null
for i = 0,39 do begin
; calculate sz, xx, yy, vertline
dummy=findgen(3,sz[1])
dummy[0,*] = xx
dummy[1,*] = yy
dummy[2,*] = vertline
ptrs[i]=ptr_new(dummy) ; create copy of dummy on the heap, storing pointer in ptrs[i]
endfor
; To access the i-th subarray...
(*ptrs[i])[0,*] = new_xx
(*ptrs[i])[1,*] = new_yy
(*ptrs[i])[2,*] = new_vertline