I want to write the following data onto excel, in a way which the first answer (M(: , : , 1)) will be at the range E to G and the next answer (M(: , : , 2)) will be at the range I to K, so 4 column space between each.The sample data is below, is there a easier to do this as sometimes there might be more than 6 data sets.
X = ones(6).*(1:6);
Y = 2*ones(6).*(1:6);
Z = 3*ones(6).*(1:6);
M = permute(cat(3,X,Y,Z), [1 3 2]);
M= reshape(M, 6, []);

댓글 수: 5

darova
darova 2020년 4월 3일
Is this correct?
Avishka G
Avishka G 2020년 4월 3일
yes the first 3 columns of the matrix should write on to EFG
darova
darova 2020년 4월 3일
Your ccode then look ok. Why don't you want it?
Image Analyst
Image Analyst 2020년 4월 3일
What code? Easier way to do what? I see no code calling xlswrite() or writematrix(). Do you have any code that actually tries to write to Excel?
Avishka G
Avishka G 2020년 4월 6일
I used xls write but i can only copy all the data in M into sheet without keeping space between the 3 columns.

댓글을 달려면 로그인하십시오.

 채택된 답변

Guillaume
Guillaume 2020년 4월 6일

0 개 추천

If I understood correctly:
xlswrite(somefile, reshape([M, nan(size(M, 1), 1, size(M, 3))], 6, []), '', 'E1')
basically pad your 3D matrix with a column of NaNs. NaNs result in empty cells in the output spreadsheet.

댓글 수: 9

Avishka G
Avishka G 2020년 4월 6일
works perfectly.... thanks alot!
Avishka G
Avishka G 2020년 4월 6일
another question if were too pad NaNs, to 4 columns between each data sets for the following data:
L=[0,70,100,150,200]
How do I do just the padding for that?
The second input to NaN is the number of pad columns, so:
xlswrite(somefile, reshape([M, nan(size(M, 1), 4, size(M, 3))], 6, []), '', 'E1')
Avishka G
Avishka G 2020년 4월 6일
I tried to do the same for variable L:
reshape([L, nan( size (L ,1), 4, size (L, 3))], 1, [])
so I get the ans,
0 70 100 150 200 NaN NaN NaN NaN
Guillaume
Guillaume 2020년 4월 7일
So, yes you get four columns of NaN which will end up as blank columns in excel. What's the problem?
Avishka G
Avishka G 2020년 4월 7일
so I wanted to get my ans like;
0 NaN NaN NaN NaN 70 NaN NaN NaN NaN 100 NaN NaN NaN NaN 150 NaN NaN NaN NaN 200 NaN NaN NaN NaN
where all the NaN is between the numbers, do you know the code for it?
Guillaume
Guillaume 2020년 4월 7일
"do you know the code for it?"
Depends on what's L. If L is a column vector, the above will work as desired.
Avishka G
Avishka G 2020년 4월 7일
I used this code but still dont get the answer i want;
L=[0,70,100,150,200].';
N=reshape([L, nan(size(L,1),1,size(L,3))], 1, [])
That's a different arrangement than in your initial question where each row of the input ended up on a different row of excel whereas you want it all in one row.
L = [0, 70, 100, 150, 200];
N = reshape([L; nan(4, size(L, 2))], 1, [])
This time, we're putting the nans below L and reshaping into a vector.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

제품

릴리스

R2016b

태그

질문:

2020년 4월 3일

댓글:

2020년 4월 7일

Community Treasure Hunt

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

Start Hunting!

Translated by