how to expand cell array?

2 visualizzazioni (ultimi 30 giorni)
andrew
andrew il 24 Ott 2013
Commentato: Azzi Abdelmalek il 14 Nov 2013
I have a cell array that contains T1-001, T2-001, T1-002, T2-002....T2-058. I am trying to expand the cell array 368x but I would like to keep them together (T1-001 with T2-002 and etc. How do I expand it so that T1-001 and T2-001 expands 368x .
  2 Commenti
dpb
dpb il 24 Ott 2013
I don't follow...how about posting a small example w/ a much smaller expansion factor and showing input/desired output?
andrew
andrew il 24 Ott 2013
for example:
  • T1-001
  • T1-001
  • T1-001
  • T2-001
  • T2-001
  • T2-001
  • T1-002
  • T1-002
  • T1-002
  • T2-002
  • T2-002
  • T2-002etc

Accedi per commentare.

Risposte (2)

Azzi Abdelmalek
Azzi Abdelmalek il 24 Ott 2013
Modificato: Azzi Abdelmalek il 24 Ott 2013
a=[sprintf('T1-00%d T2-00%d ',[1:9;1:9]) sprintf('T1-0%d T2-0%d ',[10:58;10:58]) ]
out=regexp(a,'\w+\-\w+','match')
out=reshape(repmat(out,368,1),[],1)
%or
a=sprintf('T1-%3d*T2-%3d*',[1:58;1:58])
b=regexp(a,'[^\*]\w+\-\s+\w+','match')
out=strrep(b,' ','0')
out=reshape(repmat(out,368,1),[],1)
  6 Commenti
andrew
andrew il 14 Nov 2013
how do I merge the 2 columns so that it is 'T1-001, T2-001', etc
Azzi Abdelmalek
Azzi Abdelmalek il 14 Nov 2013
a=sprintf('T1-%3d*T2-%3d*',[1:58;1:58])
b=regexp(a,'[^\*]\w+\-\s+\w+','match')
out=strrep(b,' ','0')
out=reshape(out,2,[])'
res=cellfun(@(x,y) [x ', ' y],out(:,1),out(:,2),'un',0)

Accedi per commentare.


Walter Roberson
Walter Roberson il 12 Nov 2013
idx = ndgrid(1:length(YourArray), ones(1,368));
NewArray = YourArray(idx);

Categorie

Scopri di più su Data Types in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by