Access variables with naming in workspace

I have a workspce full of data1, data2, data3.....,data100
They are all arrays with (1,n)
Instead of do it one by one via
```
matr(1,:)=data1
matr(2,:)=data2
etc
```
How can I use a loop to form this matrix

1 comentario

Stephen23
Stephen23 el 14 de Sept. de 2022
Editada: Stephen23 el 14 de Sept. de 2022
"I have a workspce full of data1, data2, data3.....,data100"
Having lots of numbered variables in the workspace is a sign that you are doing something wrong.
You did not tell us the most important information: how did you get all of these arrays into the workspace? The point where they are imported or created would be the correct place to fix your code, rather than what you are trying to do.
Whatever you do, do NOT use EVAL, ASSIGNIN, or follow any other subpar advice of that kind.

Iniciar sesión para comentar.

 Respuesta aceptada

Stephen23
Stephen23 el 14 de Sept. de 2022
This appears to be a follow up from your question from seven hours ago:
The best solution by far is to not get into the situation where you have lots of numbered variables in the workspace:
For example, you can easily LOAD into an output variable, which makes your data very easy to access (unlike what you are doing now) It assumes exactly one variable per MAT file.
N = 25;
C = cell(1,N);
for k = 1:N
F = sprintf('data%d.mat',k);
C(k) = struct2cell(load(F));
end
All of your imported filedata wll be in the cell array C. Note that you can trivially loop over all of C, or access its contents individually. For example, the data for the second file:
C{2}

Más respuestas (1)

Chunru
Chunru el 14 de Sept. de 2022
First of all, try to change the program that produces data1 to data100 by using multidimensional array or cell array if possible.
If that is not feasible for any reason, you can use eval:
matr = zeros(100, n)
for i=1:100
matr(i,:) = eval("data"+i)
end

7 comentarios

Stephen23
Stephen23 el 14 de Sept. de 2022
Reading this user's last question informs us that their bad data design is easy to avoid.
It would help both the OP and future readers of this forum, to avoid dynamically named variables.
Rik
Rik el 14 de Sept. de 2022
I have not seen a situation 'in the wild' where eval could not be avoided. I don't see a reason why you would mention eval in this thread. You only risk teaching new users eval.
The only situation I have seen is when defining anonymous functions in an m file that Matlab 6.5 can also run.
Chunru
Chunru el 14 de Sept. de 2022
@Rik Imagine that you are using other people's program (which you may have p code only) or you really don't want to spend time to change that program (good or bad). You just want to quickly do your job.
Chunru
Chunru el 14 de Sept. de 2022
Every thing has a use under certain circumstances, "eval" and "assign" and "load" included, though you may want to avoid them in most times. This should be a good advice for life in general.
Stephen23
Stephen23 el 14 de Sept. de 2022
"...using other people's program (which you may have p code only) or you really don't want to spend time to change that program (good or bad)."
By reading the OPs previous questions we can see that (just like in 99.99% of situations involving attempts to access variable names) the OP simply painted themselves into a corner. As such, this OP's situation is easily avoided.
Chunru
Chunru el 14 de Sept. de 2022
In my post, I have advised "First of all, try to change the program that produces data1 to data100 by using multidimensional array or cell array if possible".
Walter Roberson
Walter Roberson el 14 de Sept. de 2022
There is no point teaching someone to use eval until they have actually encountered a situation that could not avoid using eval.

Iniciar sesión para comentar.

Categorías

Más información sobre Variables en Centro de ayuda y File Exchange.

Productos

Versión

R2022a

Preguntada:

el 14 de Sept. de 2022

Comentada:

el 14 de Sept. de 2022

Community Treasure Hunt

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

Start Hunting!

Translated by