0

我正在尝试打开数千个 netcdf 文件并将数据提取到可以保存为 csv 文件的数据框中。

因此,在将所有 ncdf 文件名作为列表放入 csv 文件后,我最终使用此代码创建了一个数据框,其中填充了来自 ncdf 文件的数据。

vec0 <- vector()
time <- c(vec0,1:28413)

vec1 <- vector()
temp <- c(vec1,1:28413)

vec2 <- vector()
sphum <- c(vec2,1:28413)

vec3 <- vector() 
rain <- c(vec3,1:28413)

vec4 <- vector()
totprcp <- c(vec4,1:28413)

for (i in 1:length(filenames))
  {ncdata=nc_open(filenames[i]) 

 nctime=ncvar_get(ncdata,"time") 
  time[i] = nctime[1]

nctemp=ncvar_get(ncdata,"Tair_f_inst") 
  temp[i] = nctemp[1]

 nchum=ncvar_get(ncdata,"Qair_f_inst")
  sphum[i] = nchum[1]

  ncrain=ncvar_get(ncdata,"Rainf_tavg") 
  rain[i] = ncrain[1]

  ncprcp=ncvar_get(ncdata,"Rainf_f_tavg")
  totprcp[i] = ncprcp[1]
  nc_close(filenames[i])}

  cbind(time,temp,sphum,rain,totprcp)

但我只获得第一行的准确数据,并为其余行填写一系列数字(1 到 28412)。我认为我的错误在于我编写代码的 nc_close 组件的方式。有任何想法吗?

4

1 回答 1

0

nc_close()应该应用于 nc 对象本身,而不是文件名。即“ncdf4 类的对象(由函数 nc_open 或函数 nc_create 返回。”

所以,你应该使用

nc_close(ncdata)
于 2019-01-22T21:05:54.500 回答