Cell array

1 view (last 30 days)
Jason
Jason on 22 Jul 2011
If I have a cell array that consists of 1 row by n columns such as and each entry has text of the form
xx1 xx2 xx3 xx4
How can I create a single string that has each entry comma seperated. I need to create this format to enable Rowheaders for a UItable.
i.e. rowHeaders = {'xx1','xx2',xx3','xx4'};
thanks

Accepted Answer

Walter Roberson
Walter Roberson on 23 Jul 2011
rowHeaders = YourCellArrayName;
That is all you need: that is already equivalent to
rowHeaders = {YCAN{1}, YCAN{2}, YCAN{3}, ...};
  2 Comments
Jason
Jason on 23 Jul 2011
How would this be adapter where there are a variable number of elements in the array.
Thanks
Walter Roberson
Walter Roberson on 23 Jul 2011
No adaptation needed, as long as the number of elements in the cell array matches the number of row headers you need.
When YCAN is a cell array of strings, then YCAN{1} is, for nearly every purpose in MATLAB, the same thing as writing the literal string at that point. YCAN{:} is, for nearly all purposes, the same thing as writing all of the literal strings at that point, separated by commas. {YCAN{:}} would thus be the same thing as writing {'xx1', 'xx2','xx3' } and so on. And just naming the cell array, YCAN, is the same thing as {YCAN{:}} . So all you need to do is write the cell array name if it is already initialized to the strings you want.

Sign in to comment.

More Answers (2)

Fangjun Jiang
Fangjun Jiang on 22 Jul 2011
You mean this?
a={'xx1 xx2 xx3 xx4'};
b=regexp(a{1},'\s','split')
  3 Comments
Fangjun Jiang
Fangjun Jiang on 22 Jul 2011
You mean a={'xx1' 'xx2' 'xx3' 'xx4'}? Then what processing do you need? Could you just update your question to include of your example input and output?
Jason
Jason on 22 Jul 2011
I multiselect .txt files that have number name sin the format xx1, xx2 etc. I then put all of the selected files into a cell array.
Sometimes there are 12 files, sometimes 6 and sometimes 1 or 2.
I want to be able to take the cell array that has all the filenames in and put them into a rowheader in a uitable.

Sign in to comment.


Titus Edelhofer
Titus Edelhofer on 22 Jul 2011
or similarly using textscan:
b = textscan('xx1 xx2 xx3 xx4', '%s');
b = b{1}
Titus

Categories

Find more on File Operations in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!