concatenate cell

4 次查看(过去 30 天)
Alexandros
Alexandros 2011-12-20
回答: Eric Tao 2018-2-3
i have a cell (symbol {} on the variable list) with a=('kkk', 'lll', 'xxx', 'jjj.xls')
and i want to concatenate a so that i can have
b = ('kkk_lll_xxx_jjj.xls')
thank you
  2 个评论
Alexandros
Alexandros 2011-12-20
They are not with , (commas separated) they are separated with ; so they are one under the other. but i want one string at the end
Alexandros
Alexandros 2011-12-20
I don't want to separate a because it can be of infinite dimensions. i need to concatenate as much as information i have in the initial cell

请先登录,再进行评论。

采纳的回答

Andrei Bobrov
Andrei Bobrov 2011-12-20
a={'kkk', 'lll', 'xxx', 'jjj.xls'}';
out = [a(:)';repmat({'_'},1,numel(a))];
out = [out{:}];
out = out(1:end-1);
variant 2
out = cell(1,2*numel(a)-1);
out(1:2:end) = a;
out(2:2:end) = {'_'};
out = [out{:}];
  1 个评论
Alexandros
Alexandros 2011-12-20
This is perfect but it puts me a '_' also at the end which i dont need
maybe i could delete it with taking only out(1:end-1)?

请先登录,再进行评论。

更多回答(4 个)

Jan
Jan 2011-12-20
a = {'kkk'; 'lll'; 'xxx'; 'jjj.xls'}
out = sprintf('%s_', a{:});
out(end) = [];
or:
out = [sprintf('%s_', a{1:end-1}), a{end}];
or:
out = sprintf([repmat('%s_', 1, numel(a)-1), '%s'], a{:});
For very large cell strings, this becomes slow because Matlab forgets to pre-allocate the output properly. Therefore I've written the C-mex function CStr2String:
out = CStr2String(a, '_', 'noTrial')

Alexandros
Alexandros 2011-12-20
This is perfect but it puts me a '_' also at the end which i dont need
maybe i could delete it with taking only out(1:end-1)?

Alexandros
Alexandros 2011-12-20
This is very helpul guys
Thank you

Eric Tao
Eric Tao 2018-2-3
just type:
b = {strjoin(a,'_')};
Then your b will be a cell as
{'kkk_lll_xxx_jjj.xls'}

类别

Help CenterFile Exchange 中查找有关 Creating and Concatenating Matrices 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by