我想生成一个表但想要设置只有一个变量的变量名,但希望所有其他变量都保留其名称。
实施例, 说我有这个数据:
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
的所有值。如果这在某种程度上很重要。
答案 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'})