MATLAB批量读入文件和导出文件
一、 批量读入文件
1.若文件名称有序,则按照文件名称规律循环读取文件
(1)读入不同的excel
for i=1:1:10str=strcat('F:\数据\v=',int2str(i),'.xlsx'); %连接字符串形成文件名A=xlsread(str);
end
注:变量i为整数时,可以用int2str(i)将数字转化为字符串;
for i=1:0.2:2str=strcat('F:\数据\v=',num2str(i),'.xlsx'); %连接字符串形成文件名A=xlsread(str);
end
变量i为小数时,必须用num2str(i)进行转化。
(2)读入同一excel的不同sheet
for k = 1:3a = xlsread('yourname.xls',['sheet',num2str(k)]);
end
注:可以先用xlsinfo确定有多少个sheet要读
[Type Sheet Format]=xlsfinfo('file1.xls')
2.若文件名称没有规律,则从第一个文件开始读取
list=dir(['F:\数据\','*.xlsx']);
n=lendth(list);
for i=1:kstr=strcat('F:\数据\',list(i).name)A=xlsread(str)
end
二、批量导出文件
导出数据写入不同的excel
for i=1:kxlswrite(strcat(filepath,num2str(i),'.xlsx'),A,'sheet1','A1');
end
2.导出数据写入同一excel的同一sheet
(1)假如有5个数据,每循环一次写入一个数据,从A1写到E1
for i=1:5xlswrite('name.xlsx',A,'sheet1',[char(64+i),'1'])
end
注:64+i是ascii码,代入i值对应65-69,用char函数转换出来即为字符A-E。
(2)假如有5个数据,每循环一次写入一个数据,从A1写到A5
for i=1:5xlswrite('name.xlsx',A,'sheet1',['A',num2str(i)])
end
(3)假如循环一次写入多组数据,需占据一个矩形区域
xlswrite('name.xlsx',A,'sheet1','A1:B2')
3.导出数据写入同一excel的不同sheet
for 1:kxlswrite('name1.xlsx',colname,strcat('name2',num2str(i)),'A1'); %写入表头,需提前命令colname内容xlswrite('name1.xlsx',A,strcat('name2',num2str(i)),'A2');
end
注:Excel最多可以储存65536行256列;
写入数据必须是同一类型,不同类型的数据要分开写入。
MATLAB for循环
MATLAB中 for 循环是一个重复的控制结构,可以有效地写一个循环,只是执行的次数是特定的。
for循环的语法如下:
for index = values...
end
for 循环的值有下述三种形式之一:
格式 | 描述 |
initval:endval | 将索引变量从初始到终值递增1,并重复执行程序语句,直到索引值大于终值。 |
initval:step:endval | 按每次迭代中的值步骤递增索引, 或在步骤为负值时递减。 |
valArray | 在每个迭代 valArrayon 数组的后续列中创建列向量索引。 例如, 在第一次迭代中, index = valArray (:, 1),循环执行最大 n 次, 其中 n 是 valArray 的列数,由 numel (valArray, 1,:) 给出。 输入 valArray 可以是任何 MATLAB 数据类型, 包括字符串、单元格数组或结构。 |
在MATLAB中建立一个脚本文件,并输入下述代码:
例子 1(initval:endval)
for a = 10:20 fprintf('value of a: %d', a);
end
运行文件,显示下述结果:
value of a: 10 value of a: 11 value of a: 12 value of a: 13 value of a: 14 value of a: 15 value of a: 16 value of a: 17 value of a: 18 value of a: 19 value of a: 20
例子 2(initval:step:endval)
for a = 1.0: -0.1: 0.0disp(a)
end
运行文件,显示下述结果:
1 0.9000 0.8000 0.7000 0.6000 0.5000 0.4000 0.3000 0.2000 0.1000 0
例子3(valArray)
for a = [24,18,17,23,28]disp(a)
end
运行文件,显示下述结果:
24 18 17 23 28
MATLAB 中如何使用 help
语法
help
help name
描述
help 会在命令行列出所有的主要 help 主题。每一个主题对应 MATLAB 搜索路径中一个文件夹名称。
help name 显示 指定 name 对应的功能文本,name 可以是函数,方法,类,工具箱或者变量。
输入参数
name%可以是操作符,函数名,类,方法,包,工具箱文件夹,变量或其它的功能名称。
%某些类和其它包需要你指定包名。事件,属性和某些方法要求你指定类名。使用点分隔名称的组件,即:help className.name
help packageName.name
help packageName.className.name%如果 name 是变量,help 显示变量所属类的帮助文本。
help name%要使用 name 类的方法的 help,则为:
help name.methodname
示例:
如果名称重载(出现在搜索路径上的多个文件夹中),help 将显示搜索路径上找到的第一个名称实例的帮助文本,并显示重载函数及其文件夹的超链接列表。
%函数或者重载方法
%显示 MATLAB close 函数的 helphelp close%因为 close 指向函数和几个方法,所以帮助文本包含指向重载方法的超链接。
当 name 指定工具箱文件夹的名称或部分路径时:
如果文件夹包含非空的 Contents.m 文件,则 help 将显示该文件。
Contents.m 包含文件夹中的 MATLAB 程序文件列表及其说明。
如果 Contents.m 存在,但是为空,则M ATLAB 显示 No help found for name。
如果该文件夹不包含 Contents.m 文件,则 help 会列出该文件夹中每个程序文件的第一行帮助文本。
如果 name 是函数和工具箱的名称,则 help 会显示工具箱和函数的关联文本。
%使用 Database 工具箱的 close 方法的 help:
help database.close
%包,类,方法
%显示 containers 包,Map 类,isKey方法的 help:
help containers
help containers.Map
help containers.Map.isKey%也并不是所有的包,类,方法和事件都需要完整的指定。
%如类 MEception 中的 throwAsCaller 方法:
help throwAsCaller
%变量
%显示变量 t = datatime 的 help
t = datetime
help t%因为 t 是 datetime 类型的,所以 help函数会显示 datetime 类的帮助文本。%同理,如果要显示变量方法的 help,则为(Day 是 datetime 类的方法)
help t.Day
%文件夹中的函数
%通过指定部分路径,列出文件夹 matlabroot/toolbox/matlab/general 的所有函数
help general
注意
某些帮助文本以大写字符显示函数的名称,以使它们与其它部分做出区分。 键入这些函数名称时,应使用小写。 对于以混合大小写形式出现的函数名称,应键入显示名称。
要防止长描述阅读时过于耗时,应输入更多信息,然后输入帮助声明。
某些类要求指定包名称以显示帮助文本。 要标识包名称,应创建该类的实例,然后调用class(obj)。
Python 中的 help
#包
py.help('textwrap')#类
py.help('textwrap.TextWrapper')# 类方法
py.help('textwrap.TextWrapper.wrap')#函数
py.help('textwrap.fill')
Matlab保存图片
函数功能:将图像数据写入到图像文件中,存储在磁盘上
imwrite(A,filename,fmt)%参数介绍
%A是图像数据,filename是保存的图像名称,fmt是要保存的图片格式(如bmp, jpg, png等)
代码示例:
imwrite(temp,'before.jpg','jpg')
Matlab 希腊字母对照表
Α α:阿尔法 Alpha
Β β:贝塔 Beta
Γ γ:伽玛 Gamma
Δ δ:德尔塔 Delta
Ε ε:艾普西龙 Epsilon
Ζ ζ :捷塔 Zeta
Ε η:依塔 Eta
Θ θ:西塔 Theta
Ι ι:艾欧塔 Iota
Κ κ:喀帕 Kappa
∧ λ:拉姆达 Lambda
Μ μ:缪 Mu
Ν ν:拗 Nu
Ξ ξ:克西 Xi
Ο ο:欧麦克轮 Omicron
∏ π:派 Pi
Ρ ρ:柔 Rho
∑ σ:西格玛 Sigma
Τ τ:套 Tau
Υ υ:宇普西龙 Upsilon
Φ φ:fai Phi
Χ χ:器 Chi
Ψ ψ:普赛 Psi
Ω ω:欧米伽 Omega
MATLAB常用快捷键总结
编辑器窗口(Editor)下的常用快捷键: | |
自动对齐程序(整理缩进)-自动整理代码 | 用鼠标选中代码行,按Ctrl + I (我一般先 Ctrl+A 全选所有代码,再 Ctrl+I) |
快速注释代码段 | 拖动鼠标选中需要注释的代码行,按Ctrl + R |
快速取消注释代码段 | 拖动鼠标选中已经注释的代码行,按Ctrl + T |
撤销改动 | Ctrl + Z |
取消撤销(撤销过多时使用) | Ctrl + Y |
多行代码增加缩进(代码段右移) | 选中代码段,按 Tab键 或 Ctrl + ] |
多行代码减少缩进(代码段左移) | 选中代码段,按 Shift+Tab键 或 Ctrl + [ |
自动补全命令(记不全函数名时使用) | 输入函数的前几个字母,再按Tab |
查找或替换变量名、函数名 | Ctrl + F |
关闭当前的程序文本(.m)文件 | Ctrl + W |
在Editor窗体中切换 | Ctrl + PageUp/PageDown Ctrl+PgUp表示编辑器窗口向左切换文件 Ctrl+PgDn表示编辑器窗口向右切换文件 |
代码调试常用快捷键: | |
运行 | F5可保存并直接运行程序 |
执行选中代码段 | F9 |
单步执行 | F10 |
F11 | 表示step in,即当遇见子函数时,使用此快捷键,进入函数内部 |
Shift + F11 | 表示step out,即使用此快捷键,执行完子函数的剩余程序,并跳出子函数 |
设置或取消断点的方法有两种 | (1) 在要设置断点的行左侧的-处单击; (2) 可按F12设置断点。 |
直接跳至某行 | Ctrl + G, 当程序源代码很长时,可能有几百上千行。有时错误出现在很后面的地方,需要用鼠标中间的滚轮往下滚很久,才能滚到想要的那一行。这时,按Ctrl+G,就会跳出一个对话框,输入想要去的那一行的行号,就可以直接跳过去了。 |
强制中断程序的运行 | Ctrl + C |
命令窗口(Command Window)下的常用快捷键与命令: | |
再现历史命令 | 上下光标键↑↓ ,在命令窗口中,上下光标键可以调用Matlab最近使用过的历史命令,便于快速重新执行。 如果输入命令的前几个字母,再使用光标键,则只会选择以这些字母开始的命令。 上下箭头寻找此前和此后输入的命令,每次一条。 |
快速退出MATLAB | Ctrl + Q |
清除输入的命令 | Esc |
将光标处至结尾之间的代码删除 | Ctrl + K |
what | 显示当前工作路径中的所有代码文件 |
type 代码文件名 | 显示代码文件的内容 |
edit | 启动编辑器,并新建一个空白文件 |
edit 代码文件名 | 打开相应代码文件 |
whatsnew | 列出MATLAB新版本更新的内容 |
切换窗口快捷键: | |
Ctrl+0 | 命令行窗口(Command Window) |
Ctrl + Shift + 0 | 编辑器窗口(Editor) |
Ctrl + 1 | 历史命令窗口(Command History) |
Ctrl + 2 | 当前工作窗口(Current Folder) |
Ctrl + 3 | 工作空间(Workspace) |