如何仅重命名 MATLAB 表中的几个变量?

EkE*_*aas 3 matlab matlab-table

我想生成一张表,但只想设置一个变量的变量名,但希望所有其他变量保留其名称。

例如,假设我有以下数据:

User1 = rand(5,1);
User2 = rand(5,1);
User3 = rand(5,2);
Run Code Online (Sandbox Code Playgroud)

我现在可以使用以下方法制作表格:

table(User1 , User2 , User3(:,1))
Run Code Online (Sandbox Code Playgroud)

这给了我这个:

ans = 

 User1       User2        Var3  
________    ________    ________

 0.55229    0.049533     0.14651
 0.62988     0.48957     0.18907
0.031991     0.19251    0.042652
 0.61471     0.12308      0.6352
 0.36241     0.20549     0.28187
Run Code Online (Sandbox Code Playgroud)

我想得到这个:

ans = 

 User1       User2        User3  
________    ________    ________

 0.55229    0.049533     0.14651
 0.62988     0.48957     0.18907
0.031991     0.19251    0.042652
 0.61471     0.12308      0.6352
 0.36241     0.20549     0.28187
Run Code Online (Sandbox Code Playgroud)

我试图这样做:

table(User1 , User2 , User3(:,1), 'VariableNames',{'','','User3'} )
Run Code Online (Sandbox Code Playgroud)

但这给出了错误:

Error using setVarNames (line 33)
The VariableNames property must be a cell array, with each element containing one nonempty
string.

Error in table (line 305)
            t = setVarNames(t,vnames); % error if invalid, duplicate, or empty
Run Code Online (Sandbox Code Playgroud)

如何使用 MATLAB 2014b 解决我的问题?

对于我的数据,d生成并在循环中制作表格,我想保留d. 如果这在某种程度上很重要。

exc*_*aza 5

根据 MA​​TLAB 的数据类型文档table,您可以通过修改表的VariableNames属性来完成此操作。

使用示例表T

T = table(rand(3, 1), rand(3, 1), rand(3, 1));
Run Code Online (Sandbox Code Playgroud)

您可以用数字索引变量:

T.Properties.VariableNames{2} = 'Middle_Column' 
T.Properties.VariableNames(2:3) = {'Middle_Column', 'End_Column'} 
Run Code Online (Sandbox Code Playgroud)

或者您可以使用table的隐式字符串比较来索引字符串:

T.Properties.VariableNames{'Var2'} = 'Middle_Column'
T.Properties.VariableNames({'Var2', 'Var3'}) = {'Middle_Column', 'End_Column'}
Run Code Online (Sandbox Code Playgroud)

或者你可以重新分配整个事情:

T.Properties.VariableNames = {'Start_Column', 'Middle_Column', 'End_Column'}
Run Code Online (Sandbox Code Playgroud)