Readtable: Invalid parameters name

19 vues (au cours des 30 derniers jours)
Radek
Radek le 21 Fév 2022
Modifié(e) : Cris LaPierre le 21 Fév 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 commentaires
Geoff Hayes
Geoff Hayes le 21 Fév 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 le 21 Fév 2022
Modifié(e) : Radek le 21 Fév 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.

Connectez-vous pour commenter.

Réponses (2)

Cris LaPierre
Cris LaPierre le 21 Fév 2022
Modifié(e) : Cris LaPierre le 21 Fév 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 commentaires
Cris LaPierre
Cris LaPierre le 21 Fév 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 le 21 Fév 2022
Thanks! I must have missed it in documentation, sorry.

Connectez-vous pour commenter.


Radek
Radek le 21 Fév 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)

Catégories

En savoir plus sur Text Data Preparation dans Help Center et File Exchange

Tags

Produits


Version

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by