How to convert a layered structure into arrays.
5 ビュー (過去 30 日間)
古いコメントを表示
I have a structure like this
A.a.b.first, A.a.b.second, A.a.b.third
A.c.d.first, A.c.d.second, A.c.d.third
A.e.f.first, A.e.f.second, A.e.f.third
I want to extract the fields "first", "second" and "third" into arrays so that one array has all the firsts, another has all the seconds, and a thrid and all the thirds. Is there a simulink method to use or a matlab function? I am currently brute forcing it in matlab code. That is,
B(1) = A.a.b.first
B(2) = A.c.d.first
B(3) = A.e.f.first
and so forth. So it would be much better to have a loop or something even more streamlined.
4 件のコメント
Matt J
2021 年 3 月 18 日
編集済み: Matt J
2021 年 3 月 18 日
Are the desired fields always at a fixed depth (4 fields deep in your example)? Also, if the field names are not a simple alphabetical progression, what decides the order of the elements in B(i)? We need to know the general pattern before a solution can be recommended.
採用された回答
Matt J
2021 年 3 月 18 日
編集済み: Matt J
2021 年 3 月 18 日
Here's a way you can recursively search down through a tree of nested structs. Since I don't know how you want to handle multiple occurrences of the target field name (e.g. "first") on the same branch of the treee, I propose one possibility:
A.b.c.d.e.first=3;
A.g.h.first=4;
out = findField(A,'first')
function out=findField(S,tfield)
if ~isstruct(S)
out=[];
elseif isfield(S, tfield)
out=S.(tfield); %found a match
else%recurse
f=fieldnames(S);
if numel(f)==1
out=findField( S.(f{1}) , tfield);
else
for i=1:numel(f)
out{i}=findField( S.(f{i}) , tfield);
end
end
end
end
参考
カテゴリ
Help Center および File Exchange で Structures についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!