matlab中可以使用fscanf函数格式化读取文本文件中的数据
语法通常为:
[data,count] = fscanf(fid,format,size)
根据指定的格式从fid文件中按照格式format读书数据并按照size的格式保存在data中。
data: 读出的数据放入内存的变量名
count : 返回值,0: 表示失败;count大于0则表示读取成功, count是读出数据的个数
fid : 文件变量
size:data的数据维度,size一般格式为[m,n],即将原来的数据按照m行n列读入到data中,
若 size 是inf,则将全部数据输出为一列
若 size 是N, 则从中取出N个数据放在一列中
注意:fscanf是按照行读取,但是是按照列存储的。
format是字符形式,字符形式中有“%”与字符集(d,i,o,u,x,e,f,g,s,c,....)搭配构成
如: %s:单字符读
%c:读space字符
%*d表示省略整型数据,同理%*x,表示省略掉x型数据
假如有如下名为test.txt的文本数据:
如果我们只想要其中的数据,不想要中间的字符串,可以使用如下命令:
fid = fopen('test.txt', 'r');
a = fscanf(fid, '%f%*s%d', [2 inf]);
fclose(fid)
得到的a为:
由此可知,fscanf是按行读取按列存储的
如果size参数我们只写了一个数,比如
fid = fopen('test.txt', 'r');
a = fscanf(fid, '%f%*s%d', 5);
fclose(fid)
同样也是按照行读取,以读取5个数为例,得到a如下:
此时a中既有浮点数又有整数,因为我们的format中没有省略整数