24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1868  |  回复: 5

gjjzachary

银虫 (小有名气)

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

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

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的回帖

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的回帖

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的回帖

gjjzachary

银虫 (小有名气)

引用回帖:
5楼: Originally posted by libralibra at 2013-04-26 23:52:40
原贴没看到你是要挨着存到一列,不用那么复杂的,直接vertcat这2个向量,作为一个新的列向量写入位置即可.
如果你需要读入原数据,然后再写回去,由于原数据已经读入,作为开头的向量使用vertcat也可以,应该会覆盖的
测 ...

你的代码需要将之前的数据全部读出来,存入a,再ab合并,若a的数据量很大,会影响计算速度的。
我在excel中用counta后,在matlab中只是获取编号,不必涉及原先数据的长度,格式等等问题,这样是不是更加方便快捷点呢?
要想得到最好的,必须努力争第一
6楼2013-04-27 13:00:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 gjjzachary 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 压国家一区线,求导师收留,有恩必谢! +7 迷人的哈哈 2026-03-28 7/350 2026-03-28 16:47 by 催化大白
[考研] 275求调剂 +10 Micky11223 2026-03-25 14/700 2026-03-28 15:48 by Micky11223
[考研] 311(085601)求调剂 +3 liziyeyeye 2026-03-28 3/150 2026-03-28 15:29 by 1018329917
[考研] 一志愿华理,数一英一285求A区调剂 +8 AZMK 2026-03-25 11/550 2026-03-28 13:16 by AZMK
[考研] 材料与化工(0856)304求B区调剂 +8 邱gl 2026-03-27 8/400 2026-03-28 12:42 by 唐沐儿
[考研] 07化学280分求调剂 +10 722865 2026-03-23 10/500 2026-03-27 15:51 by Plutoqq
[考研] 324求调剂 +8 hanamiko 2026-03-26 10/500 2026-03-27 08:06 by hypershenger
[考研] 342求调剂 +3 加油a李zs 2026-03-26 3/150 2026-03-27 00:29 by wxiongid
[考研] 294分080500材料科学与工程求调剂 +4 柳溪边 2026-03-26 4/200 2026-03-26 21:14 by XPU李庆
[考研] 340求调剂 +3 Amber00 2026-03-26 3/150 2026-03-26 18:57 by 不吃魚的貓
[考研] 一志愿211 初试270分 求调剂 +6 谷雨上岸 2026-03-23 7/350 2026-03-26 18:55 by 不吃魚的貓
[考研] 一志愿哈工大,085400,320,求调剂 +4 gdlf9999 2026-03-24 4/200 2026-03-25 23:01 by boxking200
[考研] 07化学303求调剂 +5 睿08 2026-03-25 5/250 2026-03-25 22:46 by 418490947
[考研] 318求调剂 +3 plum李子 2026-03-23 3/150 2026-03-25 09:42 by 雾散后相遇lc
[考研] 一志愿山东大学药学学硕求调剂 +3 开开心心没烦恼 2026-03-23 4/200 2026-03-24 00:06 by 开开心心没烦恼
[考研] 接收2026硕士调剂(学硕+专硕) +4 allen-yin 2026-03-23 6/300 2026-03-23 15:04 by 汪!?!
[考研] 一志愿070300浙大化学358分,求调剂! +4 酥酥鱼.. 2026-03-21 4/200 2026-03-23 08:12 by Iveryant
[考研] 一志愿东华大学化学070300,求调剂 +7 2117205181 2026-03-21 8/400 2026-03-22 22:55 by chixmc
[考研] 石河子大学(211、双一流)硕博研究生长期招生公告 +3 李子目 2026-03-22 3/150 2026-03-22 21:01 by 怎么释怀
[考研] 求调剂院校信息 +6 CX 330 2026-03-21 6/300 2026-03-22 15:25 by 无懈可击111
信息提示
请填处理意见