我在将数据从 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 的文件,其中包含我需要的所有数据。然后使用 RI 可以单独读取所有变量,例如
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")
但我想要的是制作一个输出文件,其中每一行告诉我时间、雨量、经度和纬度。我尝试了 rbind,但它没有将正确的时间(日期)与正确的雨量相关联,并且同样弄乱了 lon 和 lat,因为有数十万个降雨数据但只有几个日期,只有 360 lon 点和 280纬度点(即降雨数据是几天内每天的数据网格)。我敢肯定这应该很容易,但是怎么做呢?
请帮忙
托尼