Why is importdata bringing in cell array?

6 ビュー (過去 30 日間)
K
K 2018 年 11 月 16 日
コメント済み: dpb 2018 年 11 月 17 日
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 件のコメント
K
K 2018 年 11 月 16 日
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 2018 年 11 月 17 日
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.

サインインしてコメントする。

採用された回答

Mark Sherstan
Mark Sherstan 2018 年 11 月 16 日
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.

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLarge Files and Big Data についてさらに検索

製品


リリース

R2016b

Community Treasure Hunt

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

Start Hunting!

Translated by