IDL中将文本文件中的数据读入二维数组Data[列,行]函数dlmread
2011-04-14 13:45
387 查看
PRO dlmread,file,Data,MaxColumn=MaxColumn ;================================================ ;该过程可以将文本文件中的数据读入一个二维数组Data[列,行] ;适用于6.x的版本,其它版本未测试,7.X版本对正则表达式支持不好 ;曾用名FileColumnData.pro,为了和Matlab一致,改名为dlmread ;使用函数:IDL>dlmread,File,Data;最大列默认为20列 ;使用函数:IDL>dlmread,File,Data,MaxColumn=5;最多读取前5列 ;使用函数:IDL>dlmread,File,Data,MaxColumn=50;最多读取前50列 ;================================================ ;wuxuping(USTC & AIAI) ;Email:539688300@qq.com ;2011-03-29 ;======================================================= IF KEYWORD_SET(MaxColumn) THEN BEGIN IF (MaxColumn LT 1) Then begin message, 'MaxColumn Must be the positve Integer number.' end MaxCoL=MaxColumn ENDIF else begin MaxCoL=20;最大列默认为20列 END ;----------------------------------------- FTresult = FILE_TEST(File) if (FTresult NE 1) then begin message, 'File Not Found!' endif ;----------------------------------------- ;初始化数据 Data=make_array(1,1,/DOUBLE);文件中没有数据时就返回此值 ;----------------------------------------- fs=fileread(file); ;----------------------------------------- ;最多MaxCoL列nn行 if (n_elements(fs) GT 0) then begin ;----------------------------------------- FileData=make_array(MaxCoL,n_elements(fs),/DOUBLE) LineCount=make_array(1,n_elements(fs),/UINT) ;=========================================================== for n=0L,n_elements(fs)-1 DO BEGIN LineStr=fs ; rbool=StringToDoubleArray(LineStr,DoubleArray,Count); ;----------------------------------------- if ((rbool eq 1) && (Count GT 0))then begin MinColSet=make_array(2,1,/DOUBLE) MinColSet[0]=MaxCoL; MinColSet[1]=Count; ;----------------------------------------- for LC=0L,min(MinColSet)-1 Do begin FileData[LC,n]=DoubleArray[LC]; endfor ;----------------------------------------- LineCount =min(MinColSet) endif ;----------------------------------------- endfor ;=========================================================== validrow=where(LineCount GT 0) ;----------------------------------------- if (max(LineCount) GT 1)AND(n_elements(validrow) GT 1) then begin Data=FileData[0:(max(LineCount)-1),validrow]; endif ;----------------------------------------- endif ;----------------------------------------- end ;======================================================= ;============================================================== ;StringToDoubleArray ;============================================================== Function StringToDoubleArray,DblStr,DoubleArray,Count ;用法IDL>Status=StringToDoubleArray(DblStr,DoubleArray,Count) ;DblStr要转换的字符串,字符串可以是'1.23 ,3.4;0.3 E2.2 afd 3er.7 ' ;DoubleArray保存double类型的数组 ;Count总共可以提取多少个double类型的数 ;返回是否成功的标志 ;---------------------------------------------------------------- Count=0 ;---------------------------------------------------------------- ;先对\t处理一下 Stab=STRSPLIT(DblStr, STRING(9b),/EXTRACT) str=STRJOIN(Stab, ' ') Si=STRSPLIT(Str,'[;,: ]',/EXTRACT,/REGEX) ;---------------------------------------------------------------- nn = n_elements(Si) ;---------------------------------------------------------------- if (nn GT 0) then begin DoubleValue=findgen(nn) LineSize=UINDGEN(nn) ;------------------------------------ for n=0L,nn-1 DO BEGIN valid=IsDoubleString(Si ) if (valid GT 0) then begin DoubleValue =fix(Si ,type=5) LineSize =1; endif else begin DoubleValue =0 LineSize =0; endelse endfor ;------------------------------------ count=total(LineSize); index=where(LineSize GT 0) ;------------------------------------ if (count GT 0) then begin DoubleArray=DoubleValue[index] endif ;------------------------------------ return,1 ;------------------------------------ endif else begin return,0 end ;---------------------------------------------------------------- END function IsDoubleString,dblstr ;用法IDL>Status=IsDoubleString(dblstr) ;Status=0或1,成功为1,否则为0 ;以下识别正确的话,肯定可以使用: ;IDL>DoubleValue=fix(dblstr,type=5)转换为double数字 ;-------------------------------------------------------------- Status=1;假设可以转换 ;先去掉首尾空格 str = STRTRIM(dblstr,2) ;--------------------------------------------- ;查找并去掉末尾的非法字符 pos = STREGEX(str, '([^0-9.eE+-]|[+-.][Ee]|[eE].)') if pos GT -1 then begin str=strmid(str,0,pos) endif ;--------------------------------------------- ;转换为ASCII inputstr = byte(str) ;获取字符个数 nn = n_elements(inputstr) ;--------------------------------------------- ;判断第一个字符的合法性 if nn GT 0 then begin FirstDoubleStr=byte('+-1234567890.') index=where(FirstDoubleStr eq inputstr[0],count) if count eq 0 then Status=0 endif else begin ;如果字符的长度小于1,也不是合法字符 Status=0 endelse ;--------------------------------------------- ;判断第二个字符的合法性 if nn GT 1 then begin SecondDoubleStr=byte('1234567890.Ee') index=where(SecondDoubleStr eq inputstr[1],count) if count eq 0 then Status=0 endif ;--------------------------------------------- ;查找字符串中数字的总数,不能小于1 num_total=0 NumberStr=byte('1234567890') for n=0L,nn-1 DO BEGIN count=0; index=where(NumberStr eq inputstr ,count) num_total=count+num_total endfor if num_total LT 1 then Status=0 ;================================= ;后续处理 ;if Status eq 1 then begin ;print,fix(dblstr,type=5) ;endif ;================================= ;--------------------------------------------- return,Status End
相关文章推荐
- fileread函数:IDL中将文本文件读入一个字符串数组中,每一行作为一个元素
- 如何从文本文件读取数据到二维数组,如何在函数处理后返回二维数组的示例
- 从文本文件读入数据到动态二维数组,文件中定义数组大小
- 43节从文本文件中读入数据!
- R语言中将数据框(data.frame)中字符型数据转化为数值型
- C++ 中将二维数组传入函数
- C语言中将二维数组作为参数传递给函数的方法
- PHP二维数组提取函数----把不需要的数据剔除
- 第四十三课 从文本文件中读入数据 【项目1-4】
- eval函数解析json数据时为什加上圆括号eval("("+data+")")
- 将datawindow中的指定列的数据导出的一个函数
- HDFS中DataNode获取数据函数
- IDL中将字符串转为double类型的数组的函数StringToDoubleArray
- C语言中将二维数组作为参数传递给函数的方法
- R语言中将数据框(data.frame)中字符型数据转化为数值型
- MATLAB中的数据写入函数dlmwrite dlmread
- C++ 中将二维数组传入函数
- echarts中将后台的json数据放入data属性
- Java从键盘读入到文件cric .txt中,再从cric.txt中将数据读入到33.txt中
- 用函数读出数据表内容放入二维数组