【IDL】读取文本中三维数组的方法

利用IDL可以自动获取文本中一维、二维甚至三维的数组。当数组为二维以上时,需要通过方法获取数组的行列数等信息。下面以三维数组为例,介绍如何使用IDL自动获取文本中保存的三维数组。

对于三维数组的保存方式有一定的要求,如图所示(习惯遥感图像了,就把第三维看成是波段吧,o(_)o ~)。本次测试未考虑数据类型,大家可参考代码进行修改。

图:测试所用三维数组及格式说明

代码如下:

  • Samples – 列数
  • Lines – 行数
  • Bands – 波段数
PRO TEST_READ_3D_TXT
  ;文件路径,自行修改
  file = 'D:\Temp\3维数组.txt'
 
  ;获取samples。因为有空行,所以不能用FILE_LINES函数。
 OPENR, lun, file, /get_lun
 WHILE ~EOF(lun) DO BEGIN
   str = ''
   READF, lun, str
   IF STRTRIM(str) NE '' THEN BEGIN
     samples = N_ELEMENTS(STRSPLIT(str))
     BREAK
   ENDIF
 ENDWHILE
 FREE_LUN, lun
 
  ;获取lines和bands, lines是总行数,除以bands得到每一维的行数。
  bands = 1L
  lines = 0L
  blank = 0
 
 OPENR, lun, file, /get_lun
 WHILE ~EOF(lun) DO BEGIN
   str = ''
   READF, lun, str
   IF STRTRIM(str) EQ '' AND blank EQ 1 THEN BEGIN
     bands++
     blank++
   ENDIF ELSE IF STRTRIM(str) NE '' THEN BEGIN
     blank = 1
     lines++
   ENDIF ELSE IF STRTRIM(str) EQ '' AND blank GT 1 THEN BEGIN
     blank++
   ENDIF
 ENDWHILE
 FREE_LUN, lun
 
 IF blank GE 2 THEN bands--
 
 PRINT, 'samples: ', samples
 PRINT, 'lines:  ', lines/bands
 PRINT, 'bands:  ', bands
 
;获取三维数组Data
  Data = INTARR(samples, lines/bands, bands)
 OPENR, lun, file, /get_lun
 READF, lun, Data
 FREE_LUN, lun
 
 PRINT, Data
 
END

 

IDL Prints

 
posted @   ENVI-IDL技术殿堂  阅读(620)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示