24小时热门版块排行榜    

查看: 1768  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

gjjzachary

银虫 (小有名气)

[求助] Matlab数据如何连续写入Excel?

在matlab中将第一个列数(n1x1)据写入excel后,第二个列数据(n2x1)想接着该列存入excel, 但 n1 n2都是不确定的,应该在xlswrite中怎么写,才能实现?
回复此楼
要想得到最好的,必须努力争第一
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

gjjzachary

银虫 (小有名气)

引用回帖:
2楼: Originally posted by libralibra at 2013-04-25 17:28:33
你可以只指定第一个range,matlab会自动根据向量长度填充的,试试下面的代码
写入2个长度分别为n1和n2的向量到A和B列
n1 = 10;
n2 = 20;
filename = 'testdata.xlsx';
sheet = 1;
xlRange = 'A1';
a = randi( ...


程序段在实验电脑上,考不出来,再打比较麻烦,就照了张图片。
要想得到最好的,必须努力争第一
4楼2013-04-26 23:02:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★ ★ ★
感谢参与,应助指数 +1
jjdg: 金币+2, 辛苦了 2013-04-26 00:43:57
ben_ladeng: 专家考核 2013-04-26 21:30:46
gjjzachary: 金币+3, ★★★很有帮助, 谢谢 2013-04-26 22:58:47
你可以只指定第一个range,matlab会自动根据向量长度填充的,试试下面的代码
写入2个长度分别为n1和n2的向量到A和B列
CODE:
n1 = 10;
n2 = 20;
filename = 'testdata.xlsx';
sheet = 1;
xlRange = 'A1';
a = randi(100,n1,1);
xlswrite(filename,a,sheet,xlRange);

xlRange = 'B1';
b = randi(200,n2,1);
xlswrite(filename,b,sheet,xlRange);

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2013-04-25 17:28:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

gjjzachary

银虫 (小有名气)

引用回帖:
2楼: Originally posted by libralibra at 2013-04-25 17:28:33
你可以只指定第一个range,matlab会自动根据向量长度填充的,试试下面的代码
写入2个长度分别为n1和n2的向量到A和B列
n1 = 10;
n2 = 20;
filename = 'testdata.xlsx';
sheet = 1;
xlRange = 'A1';
a = randi( ...

谢谢你的帮助,你的方法我之前试过了,不行。你可以help xlswrite 里面的note中说明,若excel中的选取大就会填#N/A,小就会裁剪数据,这样是不满足要求的。
我后来想到了解决方法,在excel中用counta函数寻找列的最后一个数据位置,在matlab中读取该值,再根据当前需要存的数据的长度,设置字符串,再用xlswrite函数就行了,已经试验过,很好用。
仍然很感谢你~
要想得到最好的,必须努力争第一
3楼2013-04-26 22:57:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军


gjjzachary(jjdg代发): 金币+1, 辛苦了 2013-04-27 16:24:49
引用回帖:
3楼: Originally posted by gjjzachary at 2013-04-26 22:57:41
谢谢你的帮助,你的方法我之前试过了,不行。你可以help xlswrite 里面的note中说明,若excel中的选取大就会填#N/A,小就会裁剪数据,这样是不满足要求的。
我后来想到了解决方法,在excel中用counta函数寻找列的 ...

原贴没看到你是要挨着存到一列,不用那么复杂的,直接vertcat这2个向量,作为一个新的列向量写入位置即可.
如果你需要读入原数据,然后再写回去,由于原数据已经读入,作为开头的向量使用vertcat也可以,应该会覆盖的
测试代码(先运行原来的代码生成一个xlsx文件,第一列有数据,然后运行下面的,就会发现第一列后面新添加了10个负数)
CODE:
n2 = 10;
filename = 'testdata.xlsx';
sheet = 1;
xlRange = 'A1';
a = xlsread(filename);
b = -randi(200,n2,1);
xlswrite(filename,vertcat(a,b),sheet,xlRange);

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
5楼2013-04-26 23:52:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见