Use Import's automatic table detection programatically

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 个评论

Could you post an example of the first few lines of a couple of representative files you need to handle?

请先登录,再进行评论。

更多回答(2 个)

Have you tried readtable?

2 个评论

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...

请先登录,再进行评论。

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 个评论

xlsread does about the same. Alas the two downsides are that it returns one matrix and only numeric values.
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.

请先登录,再进行评论。

Community Treasure Hunt

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

Start Hunting!

Translated by