Extracting table from data structure

3 views (last 30 days)
Haresh Kumar
Haresh Kumar on 6 Apr 2021
Commented: Haresh Kumar on 6 Apr 2021
Hello,
I have multile .mat files and from these files I want to extract the table with variable name B (500000×1 double). At first, I have loaded data using S = dir('*.mat'); and then I am using commond K = S.B; to extract the data from table variable name B. This commond doesnot work and gave me this message: Reference to non-existent field 'B'.. Can you guide me which commond will I use to extract the table data from data structure.
Br,
Haresh Kumar
  4 Comments
Stephen23
Stephen23 on 6 Apr 2021
Edited: Stephen23 on 6 Apr 2021
@Haresh Kumar: that certainly looks like the structure returned by DIR, which by default does not contain a "B" field.
Most likely you forgot to actually import some file data (possibly into a table).
Haresh Kumar
Haresh Kumar on 6 Apr 2021
Hello,
Let me make it simple. I am giving directory path inorder to run the multiple .mat files from the folder. Each .mat file (number (1)......number(n)) contains multiple tables from which I only want the table of variable B. Now, you can guide which commond will I use to get the data from variable B (Table)
Br,
Haresh Kumar

Sign in to comment.

Answers (2)

Hiro Yoshino
Hiro Yoshino on 6 Apr 2021
First thing you should do is check if S is a table variable.
If it turns out to be a table variable, then the next thing would be running the following command to check if B exists
S.Properties.VariableNames
Good luck.
  3 Comments
Hiro Yoshino
Hiro Yoshino on 6 Apr 2021
type S in the command window to see what fields S has.
Haresh Kumar
Haresh Kumar on 6 Apr 2021
name
folder
date
bytes
isdir
datenum

Sign in to comment.


Steven Lord
Steven Lord on 6 Apr 2021
At first, I have loaded data using S = dir('*.mat');
The dir function does not load data. All it does is generate a list of files in the directory with the .mat extension. To load the data you'll need to use the load function. Then if you want to check if the loaded data contains a variable named B (that has been loaded into a field of the output of load you can use isfield.
data = load('census.mat')
data = struct with fields:
cdate: [21×1 double] pop: [21×1 double]
doesItHaveAVariableB = isfield(data, 'B')
doesItHaveAVariableB = logical
0
doesItHaveAVariableCdate = isfield(data, 'cdate')
doesItHaveAVariableCdate = logical
1

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!