fseek函数matlab matlab指数e怎么输入
各位老铁们,大家好,今天由我来为大家分享fseek函数matlab,以及matlab指数e怎么输入的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!
matlab怎么导入tab文件
在编写一个程序时,经常需要从外部读入数据,或者将程序运行的结果保存为文件。MATLAB使用多种格式打开和保存数据。本章将要介绍 MATLAB中文件的读写和数据的导入导出。
13.1数据基本操作
本节介绍基本的数据操作,包括工作区的保存、导入和文件打开。
13.1.1文件的存储
MATLAB支持工作区的保存。用户可以将工作区或工作区中的变量以文件的形式保存,以备在需要时再次导入。保存工作区可以通过菜单进行,也可以通过命令窗口进行。
1.保存整个工作区
选择File菜单中的Save Workspace As…命令,或者单击工作区浏览器工具栏中的Save,可以将工作区中的变量保存为MAT文件。
2.保存工作区中的变量
在工作区浏览器中,右击需要保存的变量名,选择Save As…,将该变量保存为MAT文件。
3.利用save命令保存
该命令可以保存工作区,或工作区中任何指定文件。该命令的调用格式如下:
● save:将工作区中的所有变量保存在当前工作区中的文件中,文件名为 matlab.mat,MAT文件可以通过load函数再次导入工作区,MAT函数可以被不同的机器导入,甚至可以通过其他的程序调用。
● save('filename'):将工作区中的所有变量保存为文件,文件名由filename指定。如果filename中包含路径,则将文件保存在相应目录下,否则默认路径为当前路径。
● save('filename','var1','var2',...):保存指定的变量在 filename指定的文件中。
● save('filename','-struct','s'):保存结构体s中全部域作为单独的变量。
● save('filename','-struct','s','f1','f2',...):保存结构体s中的指定变量。
● save('-regexp', expr1, expr2,...):通过正则表达式指定待保存的变量需满足的条件。
● save('...,'format'),指定保存文件的格式,格式可以为MAT文件、ASCII文件等。
13.1.2数据导入
MATLAB中导入数据通常由函数load实现,该函数的用法如下:
● load:如果matlab.mat文件存在,导入matlab.mat中的所有变量,如果不存在,则返回error。
● load filename:将filename中的全部变量导入到工作区中。
● load filename X Y Z...:将filename中的变量X、Y、Z等导入到工作区中,如果是MAT文件,在指定变量时可以使用通配符“*”。
● load filename-regexp expr1 expr2...:通过正则表达式指定需要导入的变量。
● load-ascii filename:无论输入文件名是否包含有扩展名,将其以ASCII格式导入;如果指定的文件不是数字文本,则返回error。
● load-mat filename:无论输入文件名是否包含有扩展名,将其以mat格式导入;如果指定的文件不是MAT文件,则返回error。
例13-1将文件matlab.map中的变量导入到工作区中。
首先应用命令whos–file查看该文件中的内容:
>> whos-file matlab.mat
Name Size Bytes Class
A 2x3 48 double array
I_q 415x552x3 687240 uint8 array
ans 1x3 24 double array
num_of_cluster 1x1 8 double array
Grand total is 687250 elements using 687320 bytes
将该文件中的变量导入到工作区中:
>> load matlab.mat
该命令执行后,可以在工作区浏览器中看见这些变量,如图13-1所示。
图13-1导入变量后的工作区视图
接下来用户可以访问这些变量。
>> num_of_cluster
num_of_cluster=
3
MATLAB中,另一个导入数据的常用函数为importdata,该函数的用法如下:
● importdata('filename'),将filename中的数据导入到工作区中;
● A= importdata('filename'),将filename中的数据导入到工作区中,并保存为变量A;
● importdata('filename','delimiter'),将filename中的数据导入到工作区中,以delimiter指定的符号作为分隔符;
例13-2从文件中导入数据。
>> imported_data= importdata('matlab.mat')
imported_data=
ans: [1.1813 1.0928 1.6534]
A: [2x3 double]
I_q: [415x552x3 uint8]
num_of_cluster: 3
与load函数不同,importdata将文件中的数据以结构体的方式导入到工作区中。
13.1.3文件的打开
MATLAB中可以使用open命令打开各种格式的文件,MATLAB自动根据文件的扩展名选择相应的编辑器。
需要注意的是open('filename.mat')和load('filename.mat')的不同,前者将filename.mat以结构体的方式打开在工作区中,后者将文件中的变量导入到工作区中,如果需要访问其中的内容,需要以不同的格式进行。
例13-3 open与load的比较。
>> clear
>> A= magic(3);
>> B= rand(3);
>> save
Saving to: matlab.mat
>> clear
>> load('matlab.mat')
>> A
A=
8 1 6
3 5 7
4 9 2
>> B
B=
0.9501 0.4860 0.4565
0.2311 0.8913 0.0185
0.6068 0.7621 0.8214
>> clear
>> open('matlab.mat')
ans=
A: [3x3 double]
B: [3x3 double]
>> struc1=ans;
>> struc1.A
ans=
8 1 6
3 5 7
4 9 2
>> struc1.B
ans=
0.9501 0.4860 0.4565
0.2311 0.8913 0.0185
0.6068 0.7621 0.8214
13.2文本文件的读写
在上一节中介绍的函数和命令主要用于读写mat文件,而在应用中,需要读写更多格式的文件,如文本文件、word文件、xml文件、xls文件、图像文件和音视频文件等。本节介绍文本文件(txt)的读写。其他文件的读写,用户可以参考MATLAB帮助文档。
MATLAB中实现文本文件读写的函数如表13-1所示。
表13-1 MATLAB中文本文件读写函数
函数功能
csvread读入以逗号分隔的数据
csvwrite将数据写入文件,数据间以逗号分隔
dlmread将以 ASCII码分隔的数值数据读入到矩阵中
dlmwrite将矩阵数据写入到文件中,以 ASCII分隔
textread从文本文件中读入数据,将结果分别保存
textscan从文本文件中读入数据,将结果保存为单元数组
下面详细介绍这些函数。
1. csvread、csvwrite
csvread函数的调用格式如下:
● M= csvread('filename'),将文件filename中的数据读入,并且保存为M,filename中只能包含数字,并且数字之间以逗号分隔。M是一个数组,行数与filename的行数相同,列数为filename列的最大值,对于元素不足的行,以0补充。
● M= csvread('filename', row, col),读取文件filename中的数据,起始行为row,起始列为col,需要注意的是,此时的行列从0开始。
● M= csvread('filename', row, col, range),读取文件filename中的数据,起始行为 row,起始列为col,读取的数据由数组 range指定,range的格式为:[R1 C1 R2 C2],其中R1、C1为读取区域左上角的行和列,R2、C2为读取区域右下角的行和列。
csvwrite函数的调用格式如下:
● csvwrite('filename',M),将数组M中的数据保存为文件filename,数据间以逗号分隔。
● csvwrite('filename',M,row,col),将数组M中的指定数据保存在文件中,数据由参数 row和col指定,保存row和col右下角的数据。
● csvwrite写入数据时每一行以换行符结束。另外,该函数不返回任何值。
这两个函数的应用见下面的例子。
例13-4函数csvread和csvwrite的应用。
本例首先将MATLAB的图标转化为灰度图,将数据存储在文本文件中,再将其部分读出,显示为图形。
编写M文件,命名为immatlab.m,内容为:
% the example of functions csvread and csvwrite
I_MATLAB= imread('D:\matlab.bmp');% read in the image
I_MATLAB= rgb2gray(I_matlab);% convert the image to gray image
figure,imshow(I_matlab,'InitialMagnification',100);% show the image
csvwrite('D:\matlab.txt',I_matlab);% write the data into a text file
sub_MATLAB= csvread('D:\matlab.txt',100,100);% read in part of the data
sub_MATLAB= uint8(sub_matlab);% convert the data to uint8
figure,imshow(sub_matlab,'InitialMagnification',100);% show the new image
在命令窗口中运行该脚本,输出图形如图13-2所示。
(a)(b)
图13-2例13-3的运行结果
该例中涉及到了少量的图像处理内容,超出本书的范围,感兴趣的读者可以查阅 MATLAB帮助文档中关于Image Processing Toolbox的介绍。
2. dlmread、dlmwrite(个人觉得这个比较好用)
dlmread函数用于从文档中读入数据,其功能强于csvread。dlmread的调用格式如下:
● M= dlmread('filename')
● M= dlmread('filename', delimiter)
● M= dlmread('filename', delimiter, R, C)
● M= dlmread('filename', delimiter, range)
其中参数delimiter用于指定文件中的分隔符,其他参数的意义与csvread函数中参数的意义相同,这里不再赘述。dlmread函数与csvread函数的差别在于,dlmread函数在读入数据时可以指定分隔符,不指定时默认分隔符为逗号。
dlmwrite函数用于向文档中写入数据,其功能强于csvwrite函数。dlmwrite函数的调用格式为:
● dlmwrite('filename', M),将矩阵M的数据写入文件filename中,以逗号分隔。
● dlmwrite('filename', M,'D'),将矩阵M的数据写入文件filename中,采用指定的分隔符分隔数据,如果需要tab键,可以用“\t”指定。
● dlmwrite('filename', M,'D', R, C),指定写入数据的起始位置。
● dlmwrite('filename', M, attribute1, value1, attribute2, value2,...),指定任意数目的参数,可以指定的参数见下表。
● dlmwrite('filename', M,'-append'),如果filename指定的文件存在,在文件后面写入数据,不指定时则覆盖原文件。
● dlmwrite('filename', M,'-append', attribute-value list),叙写文件,并指定参数。
● dlmwrite函数的可用参数如表13-2所示。
表13-2 dlmwrite函数的可用参数
参数名功能
delimiter用于指定分隔符
newline用于指定换行符,可以选择“pc”或者“unix”
roffset行偏差,指定文件第一行的位置,roffset的基数为 0
coffset列偏差,指定文件第一列的位置,coffset的基数为 0
precision指定精确度,可以指定精确维数,或者采用 c语言的格式,如“.5f”
3. textread,textscan
当文件的格式已知时,可以利用textread函数和textscan函数读入。这里只介绍这两个函数应用的实例。
例13-5通过%读入文件,按照原有格式读取。
文件的内容为:
Sally Level1 12.34 45 Yes
在命令窗口中输入:
>> [names, types, x, y, answer]= textread('D:\mat.txt','%s%s%f%d%s', 1)
得到结果为:
names=
'Sally'
types=
'Level1'
x=
12.3400
y=
45
answer=
'Yes'
例13-6函数csvread和csvwrite的应用
Sally Level1 12.34 45 1.23e10 inf NaN Yes
Joe Level2 23.54 60 9e19-inf 0.001 No
Bill Level3 34.90 12 2e5 10 100 No
>> fid= fopen('D:\mat.txt');
>> C= textscan(fid,'%s%s%f%u%f%f%s');
>> fclose(fid);
13.3低级文件I/O
本节介绍一些基本的文件操作,这些操作如表13-3所示。
表13-3 MATLAB的基本文件操作
函数功能
fclose关闭打开的文件
feof判断是否为文件结尾
ferror文件输入输出中的错误查找
fgetl读入一行,忽略换行符
fgets读入一行,直到换行符
fopen打开文件,或者获取打开文件的信息
fprintf格式化输入数据到文件
fread从文件中读取二进制数据
frewind将文件的位置指针移至文件开头位置
fscanf格式化读入
fseek设置文件位置指针
ftell文件位置指针
fwrite向文件中写入数据
下面重点介绍函数fprintf。该函数的调用格式如下:
count= fprintf(fid, format, A,...),该语句将矩阵A及后面其他参数中数字的实部以 format指定的格式写入到fid指定的文件中,返回写入数据的字节数。
上面语句中,参数format由%开头,共可由4个部分组成,分别如下:
●标记(flag),为可选部分。
●宽度和精度指示,为可选部分。
●类型标志符,为可选部分。
●转换字符,为必需部分。
1.标记
标记用于控制输出的对齐方式,可以选择的内容如表13-4所示。
表13-4标记的可选内容
函数功能示例
负号(-)在参数左侧进行判别%-5.2d
加号(+)在数字前添加符号%+5.2d
空格在数字前插入空格% 5.2d
0在数字前插入0.2d
2.宽度和精度指示
用户可以通过数字指定输出数字的宽度及精度,格式如下:
● o,指定数字的宽度;
●%6.2f,指定数字的宽度及精度;
●%.2f,指定数字的精度。
例13-6 fprintf函数宽度和精度指示符示例。
在命令窗口中输入如下命令:
>> file_type= fopen('D:\type.txt','w');
>> fprintf(file_h,'%6.2f.8f\n', 1.2,-43.3);
>> fprintf(file_h,'o f\n', 1.2,-43.3);
>> fprintf(file_h,'%.2f%.8f\n', 1.2,-43.3);
>> fclose(file_h)
ans=
0
打开该文件,其内容为:
1.20-43.30000000
1.200000-43.300000
1.20-43.30000000
从上述结果可以看出宽度和精度控制的效果。
3.转换字符
转换字符用于指定输出的符号,可以选择的内容如表13-5所示。
表13-5格式化输出的标志符及意义
标志符意义
%c输出单个字符
%d输出有符号十进制数
%e采用指数格式输出,采用小写字母 e,如:3.1415e+00
%E采用指数格式输出,采用大写字母 E,如:3.1415E+00
%f以定点数的格式输出
%g%e及%f的更紧凑的格式,不显示数字中无效的 0
%G与%g相同,但是使用大写字母E
%i有符号十进制数
%o无符号八进制数
%s输出字符串
%u无符号十进制数
%x十六进制数(使用小写字母a-f)
%X十六进制数(使用大写字母A-F)
其中%o、%u、%x、%X支持使用子类型,具体情况这里不再赘述。格式化输出标志符的效果见下面的例子。
例13-7 fprintf格式化输出示例。
>> x= 0:.1:1;
>> y= [x; exp(x)];
>> fid= fopen('exp.txt','wt');
>> fprintf(fid,'%6.2f.8f\n', y);
>> fclose(fid)
ans=
0
显示该文件:
>> type exp.txt
0.00 1.00000000
0.10 1.10517092
…
0.90 2.45960311
1.00 2.71828183
例13-9利用 fprintf函数在显示器上输出字符串
>> fprintf(1,'It''s Friday.\n')
It's Friday.
在该例中,利用1表示显示器,并且用两个单引号显示单引号,使用\n进行换行。在格式化输出中,这类符号称为转义符。MATLAB中的常用转义符如表13-6所示。
表13-6 MATLAB中的常用转义符
转义符功能
\b退格
\f表格填充
\n换行符
\r回车
\ttab
\\反斜线
\''或''单引号
%%百分号
13.4利用界面工具导入数据
除前面几节介绍的函数外,也可以通过界面工具将数据导入到工作区中。本节介绍利用工作区浏览器中的工具导入数据。
matlab怎么编写function函数
在MATLAB中编写Function函数需要遵循以下步骤:
创建函数文件:使用文件浏览器或MATLAB编辑器创建文件,并将其命名为以.m结尾的扩展名(如myFunction.m)。定义函数头:在文件的开头,使用以下语法定义函数头:function [outputArgument1, outputArgument2,...]= functionName(inputArgument1, inputArgument2,...)functionName:函数的名称,应与文件名匹配。outputArgument1, outputArgument2,...:函数返回的输出参数(可选)。inputArgument1, inputArgument2,...:函数需要的输入参数(可选)。编写函数体:在函数头之后,编写函数体,它包含函数的实际操作和计算。定义输出参数:使用赋值语句将函数的输出参数分配给变量。保存函数文件:保存.m文件。示例:
%创建函数文件 myFunction.mfunction result= myFunction(x, y)%计算两个数的和并返回结果result= x+ y;end程序运行:在MATLAB命令窗口中输入以下命令来调用函数:
myResult= myFunction(3, 5)这将输出结果为8。
BESSELKMATLAB中的besselk函数
BESSELK函数是MATLAB中的一个重要工具,用于计算第二类修正贝塞尔函数Kν(z)。该函数的语法形式为K= besselk(nu, Z),其中nu是一个实数常数,Z是输入数组。函数的核心是解决方程[1]的修正贝塞尔方程,这个方程的解被称为修正贝塞尔函数。
对于非整数的ν,Kν(z)的解可以通过以下表达式表示[2]:Kν(z)= Kν(z)= Iν(z)* exp(-z),其中Iν(z)和I–ν(z)是修正贝塞尔方程的两个基本解。当ν和Z是数组时,函数返回与输入数组大小相同的Kν(z)值,如果输入是标量,则会扩展到与另一输入相同大小。
另外,当使用besselk(nu, Z, 1)调用时,会计算besselk(nu, Z)乘以exp(Z)的结果。若需要返回完成标志,可以使用[K, ierr]= besselk(...),其中ierr是一个与K同大小的数组,提供了函数执行的完成状态信息。ierr的可能值及含义如下:
0:besselk成功计算了此元素的修正贝塞尔函数。
1:输入参数非法。
2:数值溢出,返回Inf。
3:在参数简化中可能有精度损失。
4:Z或ν过大,导致不接受的精度损失。
5:未达到收敛,返回NaN。
举个例子,当z从0到1以0.2为步长递增时,可以使用format long格式来查看计算结果,如z=(0:0.2:1)'; besselk(1, z)会输出一系列的函数值。
关于fseek函数matlab到此分享完毕,希望能帮助到您。