Consolidating cells to an xlsx file

2 ビュー (過去 30 日間)
sai prasanna sai prasanna m s
sai prasanna sai prasanna m s 2023 年 4 月 11 日
コメント済み: dpb 2023 年 4 月 12 日
I have data in this format
Variables A...Z
A = 1x408 cell
B = 1x408 cell
C = 1x408 cell
.
.
Z = 1x408 cell
Each element in the 1 X 408 cell of A-Z variables is a 1X1 cell.
I want to consolidate the data and generate an excel file that looks like this
Column names: A B C D E F .......... Z
Data values: A1 B1 C1 D1 ........................Z1
A2 B2 C2 D2 ........................Z2
.
.
.
A408 ..............................................Z408
Appreciate your inputs.
Thanks
Sai
  3 件のコメント
sai prasanna sai prasanna m s
sai prasanna sai prasanna m s 2023 年 4 月 12 日
I got these variables in a .mat file
Stephen23
Stephen23 2023 年 4 月 12 日
編集済み: Stephen23 2023 年 4 月 12 日
"I got these variables in a .mat file"
To avoid the very bad situation that you are in, always LOAD MAT files into an output variable:
S = load(..)
Then process the content of the structure S. You will probably find many useful MATLAB functions to help you, e.g. FIELDNAMES, STRUCT2CELL, STRUCT2TABLE, dynamic fieldnames:
and also comma-separated lists:
"I have data in this format Variables A...Z"
Trying to process lots and lots of separate variables will force you into writing slow, complex, inefficient code. Best avoided.

サインインしてコメントする。

回答 (1 件)

dpb
dpb 2023 年 4 月 11 日
移動済み: dpb 2023 年 4 月 11 日
"I have data in this format"
A = 1x408 cell
B = 1x408 cell
C = 1x408 cell
That's your problem -- don't do that.
Create a single array of 26x408 to begin with; the result otherwise is, as you're discovering, very difficult to deal with effectively. We won't even talk about the slow, inefficient and difficult to debug alternatives -- "There be dragons...."
  4 件のコメント
sai prasanna sai prasanna m s
sai prasanna sai prasanna m s 2023 年 4 月 12 日
I got these variables in a .mat file.
dpb
dpb 2023 年 4 月 12 日
What does
whos -file yourmatfilename.mat
return? Are these the only variables in the file or do you also have to find out "who's who in the zoo" in order to process the correct variables (and only the correct variables)?
As @Stephen23 points out, load-ing the .mat file into a struct variable then provides much more flexibility in writing code, but you still need to know something about what you're writing code for. But, that does open it up to using dynamic field names.
How to approach it depends in part on just what is in the file and if it can ever change its content--if it is immutable and unless it matches the contract to contain those specific variables and all of them and is nothing if that contract isn't met, then the single hardcoded line as given above may be a viable solution.

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeLogical についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by