readtable truncates rownames if using ReadRowNames

9 visualizaciones (últimos 30 días)
cmo
cmo el 14 de Sept. de 2015
Comentada: Ed Shen el 24 de Mayo de 2023
One of the options for "readtable" is "ReadRowNames".
Apparently, when "ReadRowNames" is true, Matlab silently truncates the length of rownames to a maximum of 63 characters.
However, if you manually assigned row names to a table in Matlab, they can be of arbitrary length. (e.g. myTable.Properties.RowNames = cellArrayOfVeryLongStrings works and does not truncate row names.)
No warning is given, and this "feature" is not mentioned in any documentation or Matlab tutorial on Tables.
Note that Matlab issues various warnings when, say, Variable Names for table are too long, non-unique, contain invalid characters, etc. The crime here is that Matlab automatically "formats" incoming rownames in "readtable" without any warning or notification.

Respuesta aceptada

Peter Perkins
Peter Perkins el 15 de Sept. de 2015
cmo, you are correct, thank you for finding this bug. I will make a note to have it fixed. For the time being, you can read in the file with ReadRowNames set to false, and then assign the row names and delete the string variable.
Just out of curiosity, what names do you have that are more than 63 characters?
  5 comentarios
Steven Lord
Steven Lord el 28 de Mzo. de 2023
@Julan Prasad What release of MATLAB are you using? I suspect this is Bug Report 1295146 which is listed as affecting releases R2014a through R2015b and having been fixed in release R2016a. If you're using one of the affected releases, try upgrading to release R2016a or later.
Ed Shen
Ed Shen el 24 de Mayo de 2023
I'm using 2021b and I'm still seeing this issue.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Creating and Concatenating Matrices en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by