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

3 views (last 30 days)
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?

Accepted Answer

James Tursa
James Tursa on 5 Jul 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 Comments
AR
AR on 5 Jul 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 on 6 Jul 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).

Sign in to comment.

More Answers (0)

Categories

Find more on Structures in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!