I have written a code that generates 20 strings (the number actually varies depending on the input), all of which have the names "s_idx_?" where ? is a number from 1 to 20. Is there a command that allows me to concatenate all these strings without having to type out all the names? Thanks.

5 commentaires

Nathan Greco
Nathan Greco le 19 Juil 2011
First: it is generally nicer to create one data structure to contain all of these strings rather than creating a variable per string. Look up cell arrays, they are your friend. Rather than calling your strings s_idx_?, you could just call them s{?} where ? is your old number.
E. Elgar
E. Elgar le 19 Juil 2011
Actually I'm oversimplifying the problem a bit. This is the code I have:
for e = 1:length(c)
f = eval(c{e}); % for each c, f gives the list of cues under the condition
for g = 1:length(f) % runs through the whole string of cues (f)
i = f{g};
h = genvarname('s_idx_',who);
eval([h '= find(strcmp(''' i ''',theData.study.cue))']); % matches each i with a number from some list I have
end
end
The output is a bunch of variables called "s_idx_?". The number of variables will change if I change the input. I've tried creating cell arrays as Nathan suggested, but it doesn't seem to work.
Sean de Wolski
Sean de Wolski le 19 Juil 2011
POISON!! EVAL!! Don't do it!!
E. Elgar
E. Elgar le 20 Juil 2011
!! Other solutions then?

Connectez-vous pour commenter.

 Réponse acceptée

Sean de Wolski
Sean de Wolski le 19 Juil 2011

1 vote

Don't do it!
but if you have to:
sprintf('s_idx_%i\n',1:20)

1 commentaire

Jan
Jan le 20 Juil 2011
I agree with "Don't do it". The SPRINTF command concatenates the _names_ of the variables?! The OP wants to cat the string values.

Connectez-vous pour commenter.

Plus de réponses (1)

Jan
Jan le 20 Juil 2011

2 votes

Follow Sean's link to the FAQ. There you find the suggestion to use a cell like "s_idx{i}" instead of including the index in the name of the variables. Thjen the concatenation is easy:
s = cat(2, s_idx{:});

1 commentaire

E. Elgar
E. Elgar le 20 Juil 2011
Thank you! I think this will work.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Variables dans Centre d'aide et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by