matrix concatenation

3 次查看(过去 30 天)
Baba
Baba 2012-2-21
编辑: Anusha 2013-10-19
I need to create a text file with 3 columns. first two columns are of the same size, 100. The 3rd column just has one number in it. How can I do that?

采纳的回答

Walter Roberson
Walter Roberson 2012-2-21
With col1, col2, and col3 being column vectors:
fmt = ['%f %f %f\n' repmat('%f %f\n', 1, 99)];
fid = fopen('YourOutputFile.txt', 'wt');
fprintf(fid, fmt, col1(1), col2(1), col3(1), [col1(2:end), col2(2:end)].');
fclose(fid);
Warning: the details of the fprintf() call depend upon col1 and col2 being column vectors!
  4 个评论
Walter Roberson
Walter Roberson 2012-2-21
Sorry, dropped an important parameter. I have edited it in to the above.
Baba
Baba 2012-2-21
Perfect thank you!

请先登录,再进行评论。

更多回答(1 个)

Sean de Wolski
Sean de Wolski 2012-2-21
Do you want the third column to have 100 values the same?
If so:
A = [c1,c2,repmat(c3,100,1)];
If not:
A = [{c1} {c2} {c3}]
for more info:
doc cell
  3 个评论
Baba
Baba 2012-2-21
that one value should not repeat, just appear in the first row.
Walter Roberson
Walter Roberson 2012-2-21
In order to do it with dlmwrite(), you would have to make two dlmwrite() calls, with the second using the -append option.

请先登录,再进行评论。

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by