Use Import's automatic table detection programatically

3 views (last 30 days)
When opening a *.csv with header in the "Import" window, the data table is automatically selected. Is there a way this can be done programatically? The methods described elsewhere (importdata, textread, csvread etc) are less generic and require knowledge of either the number of headerlines or header/table contents.
  1 Comment
Walter Roberson
Walter Roberson on 19 Sep 2016
Could you post an example of the first few lines of a couple of representative files you need to handle?

Sign in to comment.

Accepted Answer

Jeremy Hughes
Jeremy Hughes on 19 Sep 2016

More Answers (2)

Sean de Wolski
Sean de Wolski on 19 Sep 2016
Have you tried readtable?
  2 Comments
C Hinderink
C Hinderink on 19 Sep 2016
Yes, it returns: "... Found 2 variable names but 1 data columns. You may need to specify a different format string, delimiter, or number of header lines." So not the auto-table detect the GUI provides...

Sign in to comment.


Star Strider
Star Strider on 19 Sep 2016
I don’t know what you included with ‘etc.’ in the file import functions you’ve used. Have you tried xlsread? It might be able to read your .csv file and do everything you want.
  2 Comments
C Hinderink
C Hinderink on 19 Sep 2016
xlsread does about the same. Alas the two downsides are that it returns one matrix and only numeric values.
Star Strider
Star Strider on 19 Sep 2016
You can get three outputs from xlsread, the first being the numeric values, the second all strings (column headers, dates, string variables), and the third everything in the file as a cell array. See Request Numeric, Text, and Raw Data in the xlsread documentation for details.

Sign in to comment.

Community Treasure Hunt

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

Start Hunting!