如何在MATLAB表中只重命名少量变量?

时间:2016-12-06 17:33:04

标签: matlab matlab-table

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

实施例, 说我有这个数据:

User1 = rand(5,1);
User2 = rand(5,1);
User3 = rand(5,2);

我现在可以使用:

制作表格
table(User1 , User2 , User3(:,1))

这给了我这个:

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

我想得到这个:

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

我试着这样做:

table(User1 , User2 , User3(:,1), 'VariableNames',{'','','User3'} )

但这会产生错误:

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

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

对于我的数据,生成d并在循环中生成表格,并且我希望保留d的所有值。如果这在某种程度上很重要。

2 个答案:

答案 0 :(得分:3)

根据MATLAB的documentation for the table data type,您可以通过修改表VariableNames property来实现此目的。

使用示例表T

T = table(rand(3, 1), rand(3, 1), rand(3, 1));

您可以用数字索引变量:

T.Properties.VariableNames{2} = 'Middle_Column' 
T.Properties.VariableNames(2:3) = {'Middle_Column', 'End_Column'} 

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

T.Properties.VariableNames{'Var2'} = 'Middle_Column'
T.Properties.VariableNames({'Var2', 'Var3'}) = {'Middle_Column', 'End_Column'}

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

T.Properties.VariableNames = {'Start_Column', 'Middle_Column', 'End_Column'}

答案 1 :(得分:-2)

  

表(User1,User2,User3(:,1),'VariableNames',{'User1','User2','User3'})