How to extract values from each structure in the .mat file

57 views (last 30 days)
Hello,
I have a .mat file that contains multiple 1*1 Structures with various names. I want to extract values of signals and assign it to a variable with same name as that Structure. And I want to repeat this process for all Structures present in my .mat file. How do I write a script to automate this process?
Below is an example of this process I would like to automate.
  1. My .mat file contains structure with signal name X (1*1 struct) that contains various fields under it
  2. I would like to extract values located at field - X.signals.values where values is 1792*1 double column with actual data values recorded for signal X
  3. I would like to assign signal name X to extracted values and save it to workspace with same signal name X
  4. I would like to repeat steps 1-3 for all structure signals in my .mat file
Please help me understand how to automate above process with MATLAB script. Please let me know if you need more explanation of above process.

Accepted Answer

Sindar
Sindar on 15 Oct 2020
keeps the names, but as fieldnames in a new struct, signals, rather than variables (see Walter's comment):
data = load('data.mat');
data_fields = fieldnames(data);
for ind=1:length(data_fields)
X = data_fields{ind};
signals.(X) = data.(X).signals.values;
end
(if you have tons of fields, there may be a faster way, likely leveraging tables)
  1 Comment
Sanket Nikam
Sanket Nikam on 19 Oct 2020
Hello Sindar,
Thanks for your inputs with sample code. I was able to make it work with your suggested approach. I just added 'assignin' line to be able to extract signals to workspace for easier post-processing. Please see below final code that is working fine for my data analysis purpose. Again, Thank you so much for your help!
data = load('201007_TestCase-1.mat');
data_fields = fieldnames(data);
for ind=2:length(data_fields)
X = data_fields{ind};
%signals.(X) = data.(X).signals.values;
assignin('base',string(X),data.(X).signals.values);
end

Sign in to comment.

More Answers (0)

Categories

Find more on Data Import and Analysis in Help Center and File Exchange

Tags

Products


Release

R2017a

Community Treasure Hunt

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

Start Hunting!