Variable name in a table with a space in it

Hello,
how can I create a variable name in a table with a space character inside?
When I use
table(data,'RowNames',{'Row1'},'VariableNames',{'Variable X'})
I get the error message
'Variable X' is not a valid name.
How can I circumvent that?

 Accepted Answer

No. I don't know of any languages that can take spaces in variable names. The usual workaround is to use a different character, often an underline or dash.

2 Comments

You're probably right. I thought of it as just a name for some coloumn of a table, but in Matlab it seems to be more than that. It's a real identifier (if I'm using the right terms).
Right. If you want, you could keep a separate array of strings, a cell array, with "friendly" names that use characters not allowed in variables of field/member names. See http://matlab.wikia.com/wiki/FAQ#What_is_a_cell_array.3F, but of course the bookkeeping might be cumbersome.

Sign in to comment.

More Answers (2)

I encountered this problem myself and found out that I don't have a problem creating and working with a table that has spaces in its header.
If you want to add spaces in your header it works without giving me any error, for example I used:
MyTable.Properties.VariableNames = {'x' 'y' 'z' 'r x' 'r y' 'r z' 'f 1'};
And to use that I wrote:
MyTable.("f 1")
Note : I am working with Matlab 2021a

2 Comments

@Jack Arnoldi thanks for the additional post. I confirmed it works in MATLAB 2021a for me. I'm wondering if this was unsupported in the versions available when this was originally asked?
Support for table and timetable variable names containing spaces was added in release R2019b. See the Release Notes for more information.

Sign in to comment.

Let me add some tips in addition to the Image Analyst accurate answer. I hope the following will help someone (working on a R2019b).
MATLAB R2019b accepts variable spaced names but it returns an error trying to access the variable directlty from the Variables tab in the GUI. For example both variables of this table
T = table({ones(8)},{1},'VariableNames',["variable 1", "variable 2"]);
are shown in the Variables tab:
Clicking on variable 2, the variable is not visible:
By the way, the variable content is in memory and becomes visible in the Command Window, prompting
T{1,1}{1}
i.e. accessing to the table cell with cell access method (MATLAB use structure access method when clicking on a table cell in the Variables tab).
A poor workourand is avoiding spaces and using Variable Descriptions (well documented in the official help) table property:
T = table({ones(8)},{1},'VariableNames',["variable_1", "variable_2"]);
T.Properties.VariableDescriptions = ["variable 1", "variable 2"];
summary(T)
Francesco

Tags

Asked:

on 24 Sep 2014

Commented:

on 26 Aug 2022

Community Treasure Hunt

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

Start Hunting!