これまでラスタスタックから書き込まれたnetcdfファイルからラスタレイヤ名を抽出しようとしています。ラスタスタックをncdfにエクスポートするとうまく動作します。たとえば、ラスタスタックからNetCDFファイルへのエクスポートR
library(raster)
library(ncdf4)
library(RNetCDF)
#Create some rasters (x3)
r1<-raster(system.file("external/test.grd", package="raster"))
r2<-r1*2
r3<-r2*3
#Stack them
rstack<-stack(r1,r2,r3)
#Give each raster layer a name - in this instance years 2014 to 2016
names(rstack)<-c("2014","2015","2016")
#Write out to netcdf format
writeRaster(rstack, "rstack.nc", overwrite=TRUE, format="CDF", varname="Temperature", varunit="degC",
longname="Temperature -- raster stack to netCDF", xname="X", yname="Y",zname="Year",
zunit="numeric")
しかし、ncdfファイルをRに読み込んだとき、Z次元(つまりYear)は保持されません。例:
#Open the new netcdf dataset and look at the Z dimention, i.e. "Year"
data.nc<- open.nc("rstack.nc")
Zdim = var.get.nc(ncfile=data.nc,variable="Year")
print(Zdim)
#[1] 1 2 3
だから、私たちが得るのは、バンド番号、つまり1,2,3です。しかし、私が必要とすること(例えば、2014,2015,2016)で定義された年で定義されたテキストです:
names(rstack)<-c("2014","2015","2016")
は、それがこれを行うことは可能です??この問題は新しいものではありません。 https://gis.stackexchange.com/questions/122167/export-band-names-with-netcdf-file-in-r
必要な情報を得るには、いくつかの複雑な回避策がありますが、大して非効率的です(スタックをマトリックスに変換してからここから操作する)。大量の余分なコードを書いたり不要なRAMを使うことなく、より洗練された方法があるかどうかは不思議です。