Renaming headers in Table

49 views (last 30 days)
Jake Bowd
Jake Bowd on 16 Jul 2020
Commented: Fangjun Jiang on 16 Jul 2020
Hi,
I want to make a table from an array by using the array2table function. This works perfectly fine for my datasets whereby table headers do not match. But on occassion I have it whereby the data will have headers that are the same. I.e.
'ground_force_px' 'ground_force_py' 'ground_force_pz' 'ground_force_vx' 'ground_force_vy' 'ground_force_vz'
'ground_force_px' 'ground_force_py' 'ground_force_pz' 'ground_force_vx' 'ground_force_vy' 'ground_force_vz'
Is there a way whereby I can to convert from array2table whilst keeping these header names the same ?
Many thanks,
  5 Comments
Jake Bowd
Jake Bowd on 16 Jul 2020
My structure looks like:
data textdata colheaders
1x290 cell 13x290 cell 295x290 double
I wish to make a table using 'data' for the data and 'colheaders' for the table headers.
I have a problem. There are repetitions in 'colheaders', which are:
'ground_force_px' 'ground_force_py' 'ground_force_pz' 'ground_force_vx' 'ground_force_vy' 'ground_force_vz'
'ground_force_px' 'ground_force_py' 'ground_force_pz' 'ground_force_vx' 'ground_force_vy' 'ground_force_vz'
and I receive the following error message:
Duplicate table variable name: 'ground_force_px'.
Question: Can I either delete the colheaders that repeat themselves along with the corresponding data, or can I rename the any colheaders that repeat?
The reason why most work is that there are no repeats of 'colheaders'. However for this particular visit, there are repeats. As such preventing from creating a table.
Fangjun Jiang
Fangjun Jiang on 16 Jul 2020
See note under Steven's answer. "duplicated headers" is the keyword here. Look back your question, you will see why three MVPs couldn't guess it right.

Sign in to comment.

Accepted Answer

Steven Lord
Steven Lord on 16 Jul 2020
I'm not sure I see the problem.
A = magic(6)
V = ["ground_force_px", "ground_force_py", "ground_force_pz", ...
"ground_force_vx", "ground_force_vy", "ground_force_vz"];
T = array2table(A, 'VariableNames', V)
If you mean you want to have a table where two of the variable names are the same, that's not allowed.
V2 = V;
V2(6) = V2(2);
T2 = array2table(A, 'VariableNames', V2) % Will error
  7 Comments
Steven Lord
Steven Lord on 16 Jul 2020
As of release R2019b table variable names don't have to be valid MATLAB identifiers. This means table arrays created with variable names that have gone through genvarname are not necessarily the same as one whose names have gone through matlab.lang.makeUniqueStrings.
A = magic(3);
V = {'hocus pocus', 'abracadabra', 'hocus pocus'};
G = genvarname(V);
T1 = array2table(A, 'VariableNames', G)
U = matlab.lang.makeUniqueStrings(V);
T2 = array2table(A, 'VariableNames', U)
Fangjun Jiang
Fangjun Jiang on 16 Jul 2020
good point! I see the difference.

Sign in to comment.

More Answers (0)

Products


Release

R2020a

Community Treasure Hunt

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

Start Hunting!