如何将数据从GrAD导出到.csv文件或从NetCDF导出到.csv?

时间:2013-12-20 14:11:41

标签: r csv netcdf grads

我很难将数据从GrADS导出到.csv文件,尽管它应该非常简单。该文件来自与亚洲降雨有关的APHRODITE项目。基本上我可以使用以下方法将此文件读入GrADS:

open d:/aphro/aphro.ctl

它告诉我:

Data file d:/aphro/APHRO_MA_025deg_V1101R2.%y4 is open as file 1
Lon set to 60.125 149.875
Lat set to -14.875 54.875
Lev set to 1 1
Time values set: 1961:1:1:0 1961:1:1:0
E set to  1 1

如果我执行:

q ctlinfo

它还告诉我,我有三个变量:

precip 1 0 daily precipitation analysis
rstn 1 0  ratio of 0.05 degree grids with station
flag 1 0 ratio of 0.05 degree grids with snow

好的,现在我要做的就是在.csv文件(或.txt)文件中生成一个列表,其中包含以下信息:

Precipitation   Lon    Lat   Time(date)

这听起来很容易,但我无法做到。一种方法是使用:

fprintf precip d:/output.csv %g 1

这给了我一个.csv文件,其中包含当天在一个长列中的整个数据(这就是我想要的)。我也可以为lon和lat在不同的文件中做同样的事情并将它们组合起来。问题是输出文件需要很长时间 - 如果你不介意很多列,它会快得多,但这会变得很难管理。基本上,这种方法太慢了。

另一种方法是通过以下方式将数据导出为NetCDF文件:

Set sdfwrite -4d d:/output.nc
define var = precip
sdfwrite precip

然后非常快速地写入一个名为output.nc的文件,其中包含我需要的所有数据。然后使用R I可以单独读取所有变量,例如

f <- open.ncdf("D:/aphro/test.nc")
A <- get.var.ncdf(nc=f,varid="time")
B <- get.var.ncdf(nc=f,varid="rain")
D <- get.var.ncdf(nc=f,varid="lon")
E <- get.var.ncdf(nc=f,varid="lat")

但我想要的是制作一个输出文件,其中每一行告诉我时间,下雨量,lon和lat。我尝试了rbind,但它没有将正确的时间(日期)与正确的降雨量相关联,同样会弄乱lon和lat,因为有数十万的降雨数据,但只有几个日期,只有360个点数和280个纬度点(即雨数据是几天内每天的数据网格)。我确定这应该很简单,但该怎么做?

请帮忙

1 个答案:

答案 0 :(得分:5)

据我所知,您可以通过使用气候数据运算符和R将GrAD文件更改为NetCDF文件。可以找到详细信息here。此外,NetCDF文件可以转换为.csv文件。为此,我提供了一个虚拟代码。

library(ncdf)
nc <- open.ncdf("foo.nc")             #open ncdf file and read variables
lon <- get.var.ncdf(nc, "lon")         # Lon lat and Time
lat <- get.var.ncdf(nc, "lat")
time <- get.var.ncdf(nc, "time")
dname <- "t"                         # name of variable which can be found by using print(nc)
nlon <- dim(lon)
nlat<- dim(lat)
nt<- dim(time)
lonlat <- expand.grid(lon, lat)    # make grid of given longitude and latitude 
mintemp.array <- get.var.ncdf(nc, dname)
dlname <- att.get.ncdf(nc, dname, "long_name")
dunits <- att.get.ncdf(nc, dname, "units")
fillvalue <- att.get.ncdf(nc, dname, "_FillValue")
mintemp.vec.long <- as.vector(mintemp.array)
mintemp.mat <- matrix(mintemp.vec.long, nrow = nlon * nlat, ncol = nt)
mintemp.df <- data.frame(cbind(lonlat, mintemp.mat))
options(width = 110)
write.csv(mintemp.df, "mintemp_my.csv")

我希望,它解释了你的问题。