24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1885  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 277求调剂 +5 考研调剂lxh 2026-04-05 5/250 2026-04-05 19:03 by chy09050039
[考研] 工科08-机械专硕-求调剂 +3 雷欧飞踢 2026-04-02 3/150 2026-04-05 18:49 by 蓝云思雨
[考研] 调剂 +4 不逢春 2026-04-05 4/200 2026-04-05 18:07 by ms629
[考研] 调剂 +5 好好读书。 2026-04-01 5/250 2026-04-05 17:54 by liucky
[考研] 285求调剂 +5 AZMK 2026-04-04 7/350 2026-04-05 17:16 by yulian1987
[考研] 358求调剂 +7 秋gk 2026-04-04 7/350 2026-04-05 13:29 by huangmoli
[考研] 考研调剂 +11 小sun要好运 2026-04-04 11/550 2026-04-05 08:02 by qlm5820
[考研] 292分,材料与化工,申请调剂 +22 程晴之 2026-04-01 26/1300 2026-04-04 22:03 by hemengdong
[论文投稿] 求文献 5+3 ys879651$ 2026-04-02 3/150 2026-04-04 17:22 by bobvan
[考研] 一志愿双非085502,267分,过四级求调剂 +3 再忙也要吃饭啊 2026-04-03 3/150 2026-04-04 05:03 by gswylq
[考研] 化学调剂求助 +6 LULONG1 2026-04-03 6/300 2026-04-03 23:13 by qzxyhcsy
[考研] 求调剂 +8 akdhjs 2026-04-03 8/400 2026-04-03 18:17 by 戴维ING
[考研] 机械专硕297 +3 Afksy 2026-04-03 3/150 2026-04-03 14:24 by 1753564080
[考研] 279求调剂 +6 qazplm0852 2026-04-02 6/300 2026-04-03 10:03 by 蓝云思雨
[考研] 调剂 +3 osbbx 2026-04-02 3/150 2026-04-03 07:47 by cc8418
[考研] 302求调剂 +9 zyx上岸! 2026-04-02 9/450 2026-04-02 23:07 by 马儿快快地跑
[考研] 0856材料与化工调剂,339 +14 10213207 2026-03-31 14/700 2026-04-02 21:01 by 1104338198
[考研] 314求调剂 +11 1xiaojun23 2026-03-31 12/600 2026-04-02 12:31 by 1xiaojun23
[考研] 266分,一志愿电气工程,本科材料,求材料专业调剂 +10 哇呼哼呼哼 2026-04-01 11/550 2026-04-02 11:31 by lnilvy
[考研] 材料调剂 +12 一样YWY 2026-04-01 12/600 2026-04-02 09:15 by olim
信息提示
请填处理意见