我有一个数组。它有lat,lon,time和value。时间从1到300开始。这是时间= 1的数组的一部分。
myarray[,,1]
lon
lat -124.5 -123.5 -122.5 -121.5 -120.5 -119.5 -118.5
31.5 0 0 0 0 0 0
32.5 0 0 0 0 0 0
33.5 0 0 0 0 0 0
34.5 0 0 0 0 0 0
35.5 0 0 0 0 0 0
36.5 0 0 0 768.1 0 126.2
37.5 0 0 0.2 0 811 212.1
38.5 0 0 3055 0 243.9 243.7
39.5 0 0 1.5 0.1 3 0
40.5 0.1 16.8 4.3 0.5 2.1 0
41.5 0.2 398.6 0.4 1.2 1.6 0
42.5 0 0.1 0.9 0.1 0.7 0
我想同时使用“write.csv”和“for loop”从每个时间步(1到300)读取数组中的数据,并将它们存储在具有“i”为的单个.csv文件中指数。我使用了这个命令,但似乎它不起作用:
for (i in 1:300) write.csv(myarray[,,i],"myarray.i.csv")
答案 0 :(得分:9)
有多种方法可以解决这个问题:
paste('myarray', i, 'csv', sep = '.')
或:
sprintf('myarray.%d.csv', i)
我更喜欢最后一个。
答案 1 :(得分:1)
一种方法是
for (i in 1:300) {
write.table(myarray[,,i],file=""myarray.i.csv"",append=TRUE,sep=",",col.names=TRUE,row.names=TRUE)
}
答案 2 :(得分:0)
这应该可以正常工作:
n = dim(mydata)[3]
for(i in 1:n) {
#unpack a 3D array
mat = mydata[,,i]
form = sprintf('subject_%s.csv', i)
write.csv(mat, file = form)
}