MATLAB对文本文件的读写
用光谱仪测量的光谱,得到数据文件(.txt)。有时候需要对光谱进行处理之后才能使用。这就涉及到MATLAB对文本文件的读取和存入操作。这里我们以一个例子来说明对文本文件读、存的操作。
一般光谱仪得到的光谱文件结构如图1所示,共包含两列,第一列为波长数值(单位:nm),第二列为测量的光功率值(单位:dBm)。两列之间用空格分割。现在假设要把光谱往短波长方向移动0.4 nm,然后再把平移之后的光谱保存为.txt文件。(假设原光谱文件为A.txt,平移后的光谱文件为B.txt)代码如下:
%==========================================================================
%Name: file_r_w.m,
%Desc: 对文本文件的读取与存入操作
%Parameter:
%Return:
%Author: yoyoba(stuyou@126.com)
%Date: 2014-5-15
%Modify: 2014-5-15
%==========================================================================
clear
clc
OS=load('A.txt'); %读入原光谱文件;
lamda=OS(:,1)'; %第一列波长数据
power=OS(:,2)'; %第二列光功率数据
lamda_shift=lamda-0.4; %波长往短波长移动0.4nm;
spa=32; %空格的ASCII码
fid=fopen('B.txt','w'); %以写的方式打开文件B.txt
for i=1:length(lamda_shift)
t=strcat(num2str(lamda_shift(i)),spa,num2str(power(i))); %构造每行的数据
fprintf(fid,'%s\r\n',t); %按行写入B.txt,且每行后加入回车符换行。
end
fclose(fid); %关闭B.txt