概述
eval的功能简单来说就是可以把字符串当做命令来执行,
之前没用到的时候对这句话不太懂,百度了一下,看到有人举的例子:
eval('y=sin(1)')与命令 y=sin(1)等价
emmm看完后虽然懂了基本用法还是一脸懵逼,道理我都懂,但是 这不是自讨无趣吗,直接打命令不是更简单吗?
最近需要把数据按天按时段导出excel我才仔仔细细地研究了一下eval函数的具体用法,真的好用!也指出了遇到的坑,帮助后面像我一样的小白:
eval用于循环中是再好不过了,特别是有些变量的名字中含有有规律的数字,比如我们现在要依次把data1,data2,data3写入excel,并命名为data1.xlsx,data2.xlsx,data3.xlsx,
当然你可以写三行:
xlswrirte('data1.xlsx',data1)
xlswrirte('data2.xlsx',data2)
xlswrirte('data3.xlsx',data3)
但是假如现在有1000个这种data1,data2,...,data1000呢
这个时候就需要eval出马了,我们也可以只用三行:
for i=1:1000
eval(['xlswrite(''data',num2str(i),'.xlsx'',','data',num2str(i),')'])
end
%注意上面的eval语句语句中第一个data前面有两个'',而xlsx后面也有两个'',这就是给我们初学者埋下的坑哈哈,两个''号中第一个'代表转义字符,意思是两个''号中第二个'号为命令中的'号,不是用来分割字符串文本的!
%使用eval时只需要先把想要表示的语句即命令写好,再用'号分割成一段段字符串,注意上面提到的'可以用作转义字符的情况
最后放一个我用来分表写入excel的实例吧,看起来复杂一点但是道理都是一模一样的:
这个是把2880个变量(15min一个,一天96个,30天2880个,按时间顺序已排好序)每96个变量一个excel,每个变量一个sheet:
clear
clc
close all
load time_volume_data.mat%载入数据
%把站点流量按天按时段写入excel文件
m=1;
day=1;
for n=1:2880
eval(['xlswrite(''data',num2str(day),'.xlsx''',',','data',num2str(n),',','''sheet',num2str(m),''')']);
if m==96
m=0;
end
if mod(n,96)==0
day=day+1;
end
m=m+1;
end
以上,希望大家eval用的愉快!
最后
以上就是满意大侠为你收集整理的matlab中eval用法的全部内容,希望文章能够帮你解决matlab中eval用法所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复