How can I refer to all fields (of a particular level) within a structure?

3 vues (au cours des 30 derniers jours)
AR
AR le 5 Juil 2018
Commenté : AR le 6 Juil 2018
Example: I have a struct such as this (simplified): Students.Gender.Height
I want to refer to and operate upon all fields regardless of gender. So, Students.Boy.6feet or Students.Girl.6feet would both be affected by the operation. Not a great example, but I hope I am conveying the need here. Is there a wildcard or () or {} type of way to index or refer to all fields of the "gender" level?

Réponse acceptée

James Tursa
James Tursa le 5 Juil 2018
What "works" is probably going to depend on what is contained in the sub-fields and what you intend to do with this data downstream in your code. E.g., for your simplistic example if you wanted to extract the data (assuming the Height was scalar):
result = cellfun(@(x)Students.(x).Height,fieldnames(Students))
That would give you a result variable that you could use downstream.
Maybe you could give us more detail on the fields of your structure, and what operations you intend.
  2 commentaires
AR
AR le 5 Juil 2018
Thanks James. I was probing a little ahead to figure out the best way to script things. As of now, I am not sure exactly what I want to do - I will have to write a little more and then get back to you on this question.
AR
AR le 6 Juil 2018
Ok, here's what I was needing to do:
I used your method to get me the result variable, call it r.
I would like to pass the value in r (which is a cell array) to another similar structure. Let's call this RivalStudent.
So, in the end, RivalStudent.(x).Height = Student.(x).Height, the latter being r, of course. How do I assign RivalStudents of both genders the same heights as those of the Students? TIA.
In reality, these are not students and genders, but the original struct looks like this: A.B(1 of 5 fields).C(1 of 40 fields, each of which contains a cell array of numbers or strings).

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Structures dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by