Create && Fill array variables resulting from the concatenation of string characters and numbers

2 visualizaciones (últimos 30 días)
Hi
I have been unsucessfully looking for an advice on a code that loops through a dataset (of cell type) and extracting each column as data vector, and hope MATLAB pundits could assist owing to the challenging feature of this task.
[i,j]=size(testdata);
k=2;
while k<=j % looping through columns
['_' num2str(k-1)'yr']=cell2mat(testdata(:,k)); %extract data from each column in "testdata "and assign it to variables "_kyr" as column vector
k=k+1;
end
--------------------------
Error: An array for multiple LHS assignment cannot contain LEX_TS_STRING.
Thanks in advance and regards

Respuestas (1)

Stephen23
Stephen23 el 19 de Ag. de 2015
Editada: Stephen23 el 19 de Jun. de 2019
  3 comentarios
Stephen23
Stephen23 el 19 de Ag. de 2015
Editada: Stephen23 el 19 de Ag. de 2015
Just use cell2mat on your whole cell array, you do not need to use separate variables. Then use indexing to quickly access the rows/columns that you require.
The links that I gave will not create "additional confusion", because they all state that creating variables names dynamically is slow, buggy and a bad idea. It is "recurrent topic" because beginners keep thinking that it is a great idea.
Isma
Isma el 19 de Ag. de 2015
Thanks. This was my idea of last resort: apply cell2mat on whole array before carrying on, but will keep going through the links to see how bad 'eval' really is to the extent that it appeared to be the solution to my data cleansing. Cheers
Thanks for the links

Iniciar sesión para comentar.

Categorías

Más información sobre Matrix Indexing en Help Center y File Exchange.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by