Readtable: Invalid parameters name

8 Ansichten (letzte 30 Tage)
Radek
Radek am 21 Feb. 2022
Bearbeitet: Cris LaPierre am 21 Feb. 2022
I am trying use readtable() function to read simple text file, however I keep geting all sorts of "Invalid parameter name" errors.
I call the function this way:
table = readtable(fileName, ...
'FileType', 'text', ...
'ReadRowNames', false, ...
'MissingRule', 'omitrow', ...
'ImportErrorRule', 'error', ...
'ReadVariableNames', false, ...
'ExpectedNumVariables', 6, ...
'Delimiter', ' ', ...
'NumHeaderLines', 2, ...
'Format', '%u32%u16%u16%u16%u32%u16', ...
'Encoding', 'ISO-8859-1' ...
)
And the errors I get are:
Error using readtable (line 498)
Invalid parameter name: MissingRule.
Invalid parameter name: ImportErrorRule.
Invalid parameter name: ExpectedNumVariables.
I undestand I can use DelimitedTextImportOptions object, however as far as I know, this option does not support skipping columns by supplying Format in starred form (like '%*u32').
  2 Kommentare
Geoff Hayes
Geoff Hayes am 21 Feb. 2022
@Radek - what does your version of MATLAB say with respect to the three parameters that are invalid? Can you find them in the documentation for your version (which is?) or are you looking at the online MATLAB documentation?
Radek
Radek am 21 Feb. 2022
Bearbeitet: Radek am 21 Feb. 2022
I dont know what you mean exactly. I use online documentation, but I believe it is relevant to my Matlab version, and my Matlab version is v2021b. All the parameters are phrased correctly exactly according to the manual.

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Cris LaPierre
Cris LaPierre am 21 Feb. 2022
Bearbeitet: Cris LaPierre am 21 Feb. 2022
I believe the error is because these options are not valid when you specify 'Format'.
The section of code in readtable that generates this error begins with this line of code (names is your input parameter names)
if any(strcmpi(names,"Format"))
If I remove 'Format' from the options, I don't get any errors.
  3 Kommentare
Cris LaPierre
Cris LaPierre am 21 Feb. 2022
Possibly. If you use detectImportOptions, you can specify which variables to read in.
For example, in this example the following option is specified:
opts.SelectedVariableNames = {'Systolic','Diastolic'};
You do not have to use variable names. You can also specify the columns by number.
Radek
Radek am 21 Feb. 2022
Thanks! I must have missed it in documentation, sorry.

Melden Sie sich an, um zu kommentieren.


Radek
Radek am 21 Feb. 2022
Thanks to @Cris LaPierre I was able to finaly read data from text file with readtable(), while skipping particular columns.
The solution is following:
opts = delimitedTextImportOptions( ...
'NumVariables', 3, ...
'VariableNames', {'name1', 'name2', 'name3',}, ...
'VariableTypes', {'uint8', 'uint16', 'uint32'}, ...
'Delimiter', {' '}, ...
'MissingRule', 'omitrow' ...
)
options.SelectedVariableNames = [1,3] % select columns here
table = readtable('./data.txt', opts)

Kategorien

Mehr zu Text Data Preparation finden Sie in Help Center und File Exchange

Tags

Produkte


Version

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by