Storing data from a for loop into a structure

3 visualizaciones (últimos 30 días)
Nicolaas Pickard
Nicolaas Pickard el 12 de Dic. de 2024
Comentada: Nicolaas Pickard el 13 de Dic. de 2024
I am trying to store all data into a single structure. The data is currently generated in a for loop cycling through various data sets (with the name of each set stored in names1 as 19x1 cell of strings). The code then runs a large number of functions to load in data and produce the desired outputs PreDonn, PostDonn etc. which I want to store in this single structure, with the field of the structure defined based on the name of each set from names1. I am certain I have used this approach in different code before and it has worked, but this time when the code runs my Output file only contains the values for the last loop, with the rest of the data missing. I believe it is writing over the Output file during each loop, but I don't know why. I have also attempted preallocating all of the desired fields of the structure but they got written over as well. Any thoughts?
for L=1:size(names1)
...
...
Output.(names1{L}).PreDonn=PreDonn;
Output.(names1{L}).PostDonn=PostDonn;
Output.(names1{L}).PreDoff=PreDoff;
Output.(names1{L}).PostDoff=PostDoff;
end
  5 comentarios
Mathieu NOE
Mathieu NOE el 12 de Dic. de 2024
excellent suggestion !
Nicolaas Pickard
Nicolaas Pickard el 13 de Dic. de 2024
Thankyou :)

Iniciar sesión para comentar.

Respuestas (1)

ScottB
ScottB el 12 de Dic. de 2024
size(names1) has 2 elements so I think that is the problem:
names = cell(1,3);
names(1,1) = 'Jim'
names(1,2) = 'Bill'
names(1,3) = 'Tyron'
PreDonn = eye(3)
sz_names = size(names)
for L = 1:sz_names(2)
Output.(names{L}).PreDonn=PreDonn;
end
whos
  1 comentario
Nicolaas Pickard
Nicolaas Pickard el 12 de Dic. de 2024
I don't think this is the issue. I've changed the code and it still has the same issue.
for L=1:size(names1,1)
...
Output.(names1{L,1}).PreDonn=PreDonn;
Output.(names1{L,1}).PostDonn=PostDonn;
Output.(names1{L,1}).PreDoff=PreDoff;
Output.(names1{L,1}).PostDoff=PostDoff;
end

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Etiquetas

Productos


Versión

R2024a

Community Treasure Hunt

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

Start Hunting!

Translated by