今天来说下如何使用Matlab读取excel的csv文件,这个有什么用呢?想必理科生大概率都会用到示波器,去抓取一些电信号或者光信号,我们从示波器导出来的就是csv文件或者图片文件,而图片文件我们无法处理。所以,一般导出csv文件,可以用Matlab去处理数据。
Matlab帮助文件
Matlab自带了一个函数csvread来读取csv文件,关于这个函数的用法,可以在Matlab命令行窗口输入如下命令获取该函数的帮助信息:
help csvread
得到结果如下:
>> help csvread
csvread Read a comma separated value file.
M = csvread('FILENAME') reads a comma separated value formatted file
FILENAME. The result is returned in M. The file can only contain
numeric values.
M = csvread('FILENAME',R,C) reads data from the comma separated value
formatted file starting at row R and column C. R and C are zero-
based so that R=0 and C=0 specifies the first value in the file.
M = csvread('FILENAME',R,C,RNG) reads only the range specified
by RNG = [R1 C1 R2 C2] where (R1,C1) is the upper-left corner of
the data to be read and (R2,C2) is the lower-right corner. RNG
can also be specified using spreadsheet notation as in RNG = 'A1..B7'.
csvread fills empty delimited fields with zero. Data files where
the lines end with a comma will produce a result with an extra last
column filled with zeros.
帮助文件解释
下面我们来解释一下:
帮助文件一共给了我们三种使用该函数的方式,该函数只可以读取数值。
- 方法一:M = csvread(‘FILENAME’),读取逗号分隔值格式的文件名。结果直接返回给M。因此,文件只能包含数值。
- 方法二:M = csvread(‘FILENAME’,R,C),从逗号分隔值格式的文件中读取数据(从R行和C列开始)。R和C从零开始,因此R=0和C=0指定文件中的第一个值。即csv文件中的第一行为该函数的第0行,csv文件中的第一列为该函数的第0列。
- 方法三:M = csvread(‘FILENAME’,R,C,RNG),只读取由RNG=[R1 C1 R2 C2]指定的范围,其中(R1,C1)是要读取的数据的左上角,R2,C2)是右下角。也可以使用电子表格表示法指定RNG,如RNG=’A1..B7’。
大致上,就是方法一读取整个文件,必须保证该文件只有数值内容,一般用不到这种方法,毕竟从示波器等导出的文件中,一定会有描述内容,即各种单位等头文件,都是英文。
方法二,即从R行开始,C列开始,一直到结束的这个范围内的数字,全部存入M,结果是一个矩阵,这种方式比较常用。
方法三,即从R1行C1列到R2行C2列之间读取数据。
实例演示
下面,我们举个例子吧。
假设我们的csv中的内容如下:假设我们文件名称为TEK001.csv
name | 3 | 0.3 | 6 |
other | 5 | 0.4 | 0 |
8 | 0.6 | 2 | |
10 | 0.7 | 5 | |
12 | 0.8 | 9 |
Matlab读取csv文件csvread函数的使用,数据举例
- 方法一无效,因为文件中包含非数字文本;
- 方法二:M = csvread(‘TEK001.csv’,0,1)表示从第0行第1列开始读取数据,即从数字3到数字9全部读取;M = csvread(‘TEK001.csv’,1,2)表示从第1行第3列开始读取数据,即从数字0.4到数字9全部读取。这里,我们只要知道Matalb里的第几行第几列到文件中即表示第几+1行第几+1列即可。
- 方法三:M = csvread(‘TEK001.csv’,0,1,[0 1 1 2])表示读取第0行第1列到第1行第2列之间的数字,即3到0.4之间的数字;需要注意的是,数字起始点0,1前后必须一致,即方法三中的RC必须与R1C1一样。
相比来说,我还是喜欢方法二。
然后,接下来读取完数据,就是数据处理了。主要是将M中的值赋值给新元素,用于画图或处理,如下
M = csvread('TEK001.csv', 1,3,[1 3 2000 4]);
x=M(:,1);
y=M(:,2);
[i,k]=size(M);
for j=1:i
if y(j)<2
y(j)=0;
else y(j)=5;
end
end
plot(x,y)
表示从1行第3列到第2000行第4列直接的数字存入M,对应csv文件中的第2行第4列到第2001行第5列之间的数字,M得到一个20000行2列的矩阵。
第二行代码表示把矩阵中的第一列赋值给x。
第三行代码表示矩阵中的第二列赋值给y。
第四行代码表示读取举证的行数与列数
第五行到第 十行,表示把y值中小于2的值等于0,其他保持不变
第十一行为以x为横坐标,y为纵坐标作图,意思性放个结果吧,如下图:
原创文章,作者:古哥,转载需经过作者授权同意,并附上原文链接:https://iymark.com/articles/100.html