Why is importdata bringing in cell array?

5 views (last 30 days)
I have two different .csv files that I would like to import and create structure arrays.
I'm using this:
A = importdata(filepath, filename);
The first one works and the heading looks like this:
1.JPG
The second one comes in as cell array so I cannot grab A.data:
2.JPG
What is the difference that I'm not seeing?
  3 Comments
K
K on 16 Nov 2018
Thanks for the response!
By "works" I mean just having the ability to grab an array of all data points in the data file. The second file comes in as a cell array that is made up of only one column
3.JPG
I'm just trying to get a program that grabs that data no matter how many header lines there are. I definitely might be able to get it using readtable but it will be inefficient if I use this in the code.
dpb
dpb on 17 Nov 2018
What data, specifically are you wanting and how do you expect MATLAB to know where those data are or how they're organized for any totally arbitrary file excepting by some sort of preprocessing procedure?
detectImportOptions is the TMW-supplied routine to make a stab at that; anything else you do will be some variant of the techniques used therein.

Sign in to comment.

Accepted Answer

Mark Sherstan
Mark Sherstan on 16 Nov 2018
You might have better luck going through the file line by line. For example:
f = fopen('test.csv');
lineCount = 1;
tline = fgetl(f);
while ischar(tline)
data{lineCount} = tline;
tline = fgetl(f);
lineCount = lineCount + 1;
end
fclose(f);
This will give you the header information as well but you can cut that out with a string compare assuming you know the header names or when the data becomes a number instead of a string. Just depends on how different all the .csv's might be.

More Answers (0)

Categories

Find more on Large Files and Big Data in Help Center and File Exchange

Products


Release

R2016b

Community Treasure Hunt

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

Start Hunting!