R语言nc转tif

R语言nc转tif

ruby 复制代码
getwd()
setwd("E:/Program1//input/surfout-beijing-202007/")
library(ncdf4) # package for netcdf manipulation
library(sp)
library(raster) # package for raster manipulation
library(rgdal) # package for geospatial analysis
library(ggplot2) # package for plotting
library(gstat)
library(maptools)
library(readxl)
library(tidyr)
library(sf)
library(openxlsx)
rm(list=ls()) 
####nc读取####
nc_data <- raster('../wrfout_d03_2020-08-02_00_00_00.nc')

T2=data.frame()
for (day in 1:31) {
  day=1
  # 假设站点数据存储在另一个文件中
  julyday <- sprintf("%02d", day)
  nc=paste("surfout_d03_2020-07-", julyday, "_00_00_00", sep = "")
  #nc_open 将数据读入我称为 nc_data 的数据结构中
 nc_data <- brick(nc,varname = T2)
 
#which(names(nc_data)=="T2_1")409-432
#由于此NC文件没有坐标系,定义栅格文件的坐标系为WGS1984
crs(nc_data)="+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs" 

#stack#
input_nc="surfout_d03_2020-07-01_00_00_00"
ncfile<-nc_open(input_nc) 
names(ncfile$var) 
nc_stack = stack(input_nc,varname="T2")
crs(nc_stack)="+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs" 
#brick 适用于处理具有相同空间范围和分辨率的多维栅格数据,brick函数效率高
#stack 则更适用于处理不同范围和分辨率的栅格数据,或者简单地堆叠多个栅格图层。


####提取站点####
df <- data.frame(lon=116.28,lat=39.48)
bb <- SpatialPoints(df)
crs(bb)="+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs" 
p <- raster::extract(nc_data,bb)
dim(p)
class(p)
#选择温度的列
T=p[,409:432]

#转置
#T2=t(T)
T2_df <- stack(T, as.data.frame = TRUE)
T2=rbind(T2,T2_df)
# 重新设置列名为 "T2"
}
head(T)
output_folder <- "../../output/"
station_city_file <- paste(output_folder,"wrf_point_data.xlsx", sep = "")
write.xlsx(T2,station_city_file , rowNames= FALSE)


####~~~~~~~~~~~~~####
####法一#####
##读取单变量长时间序列nc数据
ncfile<-nc_open("surfout_d03_2020-07-01_00_00_00")
names(ncfile$var)
input_nc = 'surfout_d03_2020-07-01_00_00_00'
varname = 'T2'
raster1 = stack(input_nc, varname = varname)
#设置输出路径名
outpath<-"../../output/test/"
##为文件名设置做准备
x1<-c(1:24)
x2<-paste("2020_7_0_",x1,sep = "")
out_filename<-sapply(x2, function(x)paste(x,".tif",sep = ""))  #输出tif格式

out_path<-sapply(out_filename,function(x){
  paste(outpath,x,sep = "/")})      #输出路径名
#批量输出
for(i in 1:24){
  writeRaster(raster1[[i]],out_path[i], format = 'GTiff', overwrite = T)
} 


#####法二#####
library(terra)
prebr <- rast("F:/test/out/pre_2020.nc")
terra::writeRaster(prebr,paste0("F:/test/out2/2020_",names(prebr),'.tif'),
                   overwrite = T,filetype = "GTiff") 

####法三####
library(raster)
library(ncdf4)
ncfile<-nc_open("F:/test/pre_2020.nc")
names(ncfile$var) #查看varname
prebr <- brick("F:/test/pre_2020.nc")
raster::writeRaster(prebr, filename = paste0("F:/test/out1/2020_",prebr@data@names),bylayer=T, format="GTiff",varname = 'pre') 

R语言读取nc数据

相关推荐
Omics Pro10 小时前
基因泰克:检测级虚拟细胞基准!大语言模型+智能体
大数据·数据库·人工智能·机器学习·语言模型·自然语言处理·r语言
Omics Pro1 天前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
2401_868534781 天前
【无标题】
数据结构·r语言
asyxchenchong8883 天前
R+VIC 模型融合实践技术应用及未来气候变化模型预测
开发语言·r语言
生信大杂烩4 天前
从 Seurat 到 AnnData:用 anndataR 打通 R 与 Python 单细胞数据生态
python·算法·数据分析·r语言
Sylvia-girl4 天前
R语言基本语法
开发语言·r语言
赵钰老师5 天前
R语言与作物模型(以DSSAT模型为例)融合应用
开发语言·数据分析·r语言
hef2888 天前
R包grafify:简单操作实现高效统计绘图
开发语言·python·r语言
oo哦哦8 天前
矩阵系统的流行病学密码:用SIR传染模型和基本再生数R₀,解释为什么你的100条种草内容,传播力还不如别人1条
线性代数·矩阵·r语言
Omics Pro9 天前
免费!糖蛋白质组学数据分析
开发语言·深度学习·数据挖掘·数据分析·r语言·excel·知识图谱