【212】HDF更新数据&HDF创建
HDF更新数据:对原有HDF数据进行数据更新,不破坏HDF的数据结构
pro add_data_sst
;实现将SST增加1度,再将结果更新到SST中
;1. 获取SST索引
;2. 通过索引获取ID
;3. 获取SST数组
;4. 对数组进行操作
;5. 将数值进行更新
cd, 'D:\McDelfino\dell-dev\IDL'
file='D:\McDelfino\dell-dev\IDL\A20080200505006.L2_LAC' ;打开HDF文件,获取SD ID,注意使用关键字RDWR,可以读写HDF文件。
sd_id=HDF_SD_START(file, /RDWR) ;获取SD中SST的索引
sstIndex = HDF_SD_NAMETOINDEX(sd_id,'sst') ;获得SST所在索引的ID
SSTSD_ID = HDF_SD_SELECT(sd_id, sstIndex) ;读取SST数据
HDF_SD_GETDATA, SSTSD_ID, SSTData ;获取sst的实际值
;slope=0.005, intercept=0.0
realSSTData = SSTData * 0.005 + 0.0
;处理SST数据
tempSSTData = realSSTData+1
;从真实值返回
newSSTData = (tempSSTData - 0.0)/0.005 ;将新数据写出,更新原有数据
HDF_SD_ADDDATA, SSTSD_ID, newSSTData ;关闭SD,关闭HDF文件
HDF_SD_ENDACCESS, SSTSD_ID
HDF_SD_END, sd_id end
新建HDF文件:将原HDF中的数据进行计算,将结果写入新的HDF文件中
pro readandcreate
;实现数据的计算以及新建数据
;1. 读取经纬度数据
;2. 读取SST数据,并存到数组中
;3. 读取Rrs数据,并进行计算获取SD、TSM、CHL结果,存到数组中
;4. 新建HDF,将经纬度以及结果写入进去 file='D:\McDelfino\dell-dev\IDL\A20080200505006.L2_LAC'
hdfid=HDF_SD_START(file, /rdwr) ;读取数据中的lat数据
;通过latitude来获取相应的索引值
index=HDF_SD_NAMETOINDEX(hdfid, 'latitude')
;通过索引值获取ID值
varid=HDF_SD_SELECT(hdfid, index)
;通过ID值获取数组值
HDF_SD_GETDATA, varid, latdata
help,latdata ;读取数据中的lon数据
index=hdf_sd_nametoindex(hdfid, 'longitude')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, londata ;读取数据中的sst数据,有数据的进行计算,mask的部分赋值为NaN
sstdata1=dindgen(1354,2040) index=hdf_sd_nametoindex(hdfid, 'sst')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, sstdata for i=0, 1354-1 do begin
for j=0, 2040-1 do begin
if(sstdata[i,j] gt -32767) then begin
sstdata1[i,j]=sstdata[i,j]*0.005
endif else begin
sstdata1[i,j]='nan'
endelse
endfor
endfor ;读取数据中的Rrs_667数据,有数据的进行SD的计算,mask的部分赋值为NaN
rrs667data1=dindgen(1354,2040)
sddata1=dindgen(1354,2040) index=hdf_sd_nametoindex(hdfid, 'Rrs_667')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, rrs667data for i=0, 1354-1 do begin
for j=0, 2040-1 do begin
if(rrs667data[i,j] gt -32767) then begin
rrs667data1[i,j]=rrs667data[i,j]*(2.0E-6) + 0.05
;只对正数进行计算
if(rrs667data1[i,j] gt 0) then begin
sddata1[i,j]=-85.666-108.807*alog10(rrs667data1[i,j])-45.591*(alog10(rrs667data1[i,j]))^2.0-6.426*(alog10(rrs667data1[i,j]))^3.0
endif else begin
sddata1[i,j]='nan'
endelse
endif else begin
sddata1[i,j]='nan'
endelse
endfor
endfor ;读取数据中的Rrs_645数据,有数据的进行TSM的计算,mask的部分赋值为NaN
rrs645data1=dindgen(1354,2040)
tsmdata1=dindgen(1354,2040) index=hdf_sd_nametoindex(hdfid, 'Rrs_645')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, rrs645data for i=0, 1354-1 do begin
for j=0, 2040-1 do begin
if(rrs645data[i,j] gt -32767) then begin
rrs645data1[i,j]=rrs645data[i,j]*(2.0E-6) + 0.05
;只对正数进行计算
if(rrs645data1[i,j] gt 0) then begin
tsmdata1[i,j]=1.572+2172.239*rrs645data1[i,j]
endif else begin
tsmdata1[i,j]='nan'
endelse
endif else begin
tsmdata1[i,j]='nan'
endelse
endfor
endfor ;读取数据中的Rrs_488/Rrs_547数据,有数据的进行CHL的计算,mask的部分赋值为NaN
rrs488data1=dindgen(1354,2040)
rrs547data1=dindgen(1354,2040)
chldata1=dindgen(1354,2040) index=hdf_sd_nametoindex(hdfid, 'Rrs_488')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, rrs488data index=hdf_sd_nametoindex(hdfid, 'Rrs_547')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, rrs547data for i=0, 1354-1 do begin
for j=0, 2040-1 do begin
if(rrs488data[i,j] gt -32767) then begin
rrs488data1[i,j]=rrs488data[i,j]*(2.0E-6) + 0.05
rrs547data1[i,j]=rrs547data[i,j]*(2.0E-6) + 0.05
;只对正数进行计算
if(rrs488data1[i,j] gt 0 && rrs547data1[i,j] gt 0) then begin
R=alog10(rrs488data1[i,j]/rrs547data1[i,j])
chldata1[i,j]=10^(4.608-14.742*R+22.025*R^2-13.509*R^3)
endif else begin
chldata1[i,j]='nan'
endelse
endif else begin
chldata1[i,j]='nan'
endelse
endfor
endfor ;读取数据中的chlor_a数据,有数据的进行计算,mask的部分赋值为NaN
chlordata1=dindgen(1354,2040) index=hdf_sd_nametoindex(hdfid, 'chlor_a')
varid=hdf_sd_select(hdfid, index)
hdf_sd_getdata, varid, chlordata for i=0, 1354-1 do begin
for j=0, 2040-1 do begin
if(chlordata[i,j] gt -32767) then begin
chlordata1[i,j]=chlordata[i,j]*1.0
endif else begin
chlordata1[i,j]='nan'
endelse
endfor
endfor hdf_sd_endaccess, varid
hdf_sd_end, hdfid ;新建HDF的文件路径
file='D:\McDelfino\dell-dev\IDL\sst23.hdf'
;以create的形式打开文件
hdfid=HDF_SD_START(file, /create)
;新建latitude变量,在HDF上显示1354列,2040行,默认是浮点型数组
sds_id=HDF_SD_CREATE(hdfid, 'latitude', [1354, 2040], /double)
;由于从HDF中读取的数据与实际数据存在一个中心对称的关系,因此通过两个reverse实现
;latdata就是从其他HDF中读取的数组,将数组的结果添加到变量latitude中去
HDF_SD_ADDDATA, sds_id, reverse(reverse(latdata), 2) sds_id=HDF_SD_CREATE(hdfid, 'longitude', [1354, 2040], /double)
HDF_SD_ADDDATA, sds_id, reverse(reverse(londata), 2) sds_id=HDF_SD_CREATE(hdfid, 'sst', [1354, 2040], /double)
HDF_SD_ADDDATA, sds_id, reverse(reverse(sstdata1), 2) sds_id=HDF_SD_CREATE(hdfid, 'sd', [1354, 2040], /double)
HDF_SD_ADDDATA, sds_id, reverse(reverse(sddata1), 2) sds_id=HDF_SD_CREATE(hdfid, 'tsm', [1354, 2040], /double)
HDF_SD_ADDDATA, sds_id, reverse(reverse(tsmdata1), 2) sds_id=HDF_SD_CREATE(hdfid, 'chl', [1354, 2040], /double)
HDF_SD_ADDDATA, sds_id, reverse(reverse(chldata1), 2) sds_id=HDF_SD_CREATE(hdfid, 'chlor_a', [1354, 2040], /double)
HDF_SD_ADDDATA, sds_id, reverse(reverse(chlordata1), 2) HDF_SD_ENDACCESS, sds_id
HDF_SD_END, hdfid end
【212】HDF更新数据&HDF创建的更多相关文章
- 常用sql语句总结(二)(更新数据,序列,创建数据表,约束,注释)
常用sql语句总结(二)(更新数据,序列,创建数据表,约束,注释) 一. 增 INSERT INTO 数据表(字段,字段,-) VALUES(值,值-); INSERT INTO emp(empno, ...
- MySQL视图-(视图创建,修改,删除,查看,更新数据)
视图是一种虚拟存在的表,对于使用视图的用户来说基本上是透明的.视图并不在数据库中实际存在,行和列数据来自定义视图的查询总使用的表,并且是在使用视图时动态生成的. 视图相对于普通表的优势: 简单:使用视 ...
- HDF 文件数据的读取
http://www.cams.cma.gov.cn/cams_973/cheres_docs/cheres_doc_sat.modis.1b.html一. HDF文件格式 1.概述 HDF 是美国国 ...
- SQL Server通过创建临时表遍历更新数据
前言: 前段时间新项目上线为了赶进度很多模块的功能都没有经过详细的测试导致了生成环境中的数据和实际数据对不上,因此需要自己手写一个数据库脚本来更新下之前的数据.(线上数据库用是SQL Server20 ...
- MeteoInfoLab脚本示例:SeaWiFS HDF Grid数据
SeaWiFS HDF Grid数据读取,特别是涉及到了文件的众多属性数据的读取,数据取对数后绘图.脚本程序: #Add data file f = addfile('D:/Temp/hdf/S199 ...
- Salesforce LWC学习(三十五) 使用 REST API实现不写Apex的批量创建/更新数据
本篇参考: https://developer.salesforce.com/docs/atlas.en-us.224.0.api_rest.meta/api_rest/resources_compo ...
- CRL快速开发框架系列教程三(更新数据)
本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...
- flask+sqlite3+echarts3+ajax 异步更新数据
结构: /www | |-- /static |....|-- jquery-3.1.1.js |....|-- echarts.js(echarts3是单文件!!) | |-- /templates ...
- 使用AjaxPro实现无刷新更新数据
需求 在一个页面动态无刷新的更新后台得到的数据.要想无刷新的更新数据,需要使用Javascript能够获取后台返回的数据,然后通过第三方Javascript库(JQuery等)动态更新web页面DOM ...
随机推荐
- crontab 实际的应用
每二天执行一次: 0 0 */2 * * command #注意分,时不能为星*,否则每分钟执行 每天零晨01,03执行: 0 01,03 * * * command 每2小时执行一次 0 */2 * ...
- Cocoa开发中, 如何用全局变量
比如在tabbar的开发中,可以某个页面的数据需要在back到此页面后依然有效. 可以用 appDelegate 这个对象来创建你的全局数据 这个内建的对象,在 APP 启动时产生,在 APP 退出时 ...
- 【JSON注解】注解@JsonIgnoreProperties和@JsonIgnore的另一个使用情况
之前关于这两个注解,是用在JSON循环引用的情况上,那么现在关于这两个注解,还可以使用在另外一种情况上 即: 一般标记在属性或者方法上,返回的json数据即不包含该属性 关于这种情况在什么时候会遇到呢 ...
- 普元OA平台介绍
Primeton Portal提供了访问企业信息资源的统一入口,是一个面向企业的内容管理.信息发布和集成展现平台,提供了单点登录.内容管理.信息发布.应用集成.个性化等功能,能够帮助企业快速搭建一个集 ...
- 【paddle学习】词向量
http://spaces.ac.cn/archives/4122/ 关于词向量讲的很好 上边的形式表明,这是一个以2x6的one hot矩阵的为输入.中间层节点数为3的全连接神经网络层,但你看右 ...
- 零售连锁行业SOA化解决方式
零售连锁行业面临的问题 1.店铺老化.营销手段单一落后. 2.管理模式的不科学,我国零售企业在起家时候并没有一套完好的科学的管理及考评系统的存在.而且在企业的发展过程中并未学习建立.对于人才的吸引.培 ...
- python实现的websocket总结 —— wspy
之前曾有php版的websocket封装包.见Websocket--php实战,近期使用python做一些功能,须要用到对websocket的操作,因此,參照之前的实现,实现了这个python版本号. ...
- 基于DM642 RAW采集格式的视频驱动开发及应用
摘 要:为解决C64X系列数字信号处理器(DSP)视频驱动不能应用于原始数据格式(RAW)采集格式的问题,设计了DM642和电耦合元件(CCD)高清传感器的数据传输接口,并分析.修改用于标准格式的视频 ...
- 对FreeMarker技术的思考
依照静态非静态来划分网页分为两种:静态网页和非静态网页,究其优缺点而言,静态网页在用户訪问的时候响应快,可是因为里面的数据是写死的.所以致命的缺陷就是数据不能动态显示.非静态页面(如jsp)数据能够动 ...
- Quartz深入浅出(二)
Hello Quartz / 本文通过一个简单的样例让大家高速了解Quartz,上手.并了解Quartz内的一些关键对象 如 Scheduler.Job.Trigger.JobExecutionCon ...