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. 如果这在某种程度上很重要。
根据 MATLAB 的数据类型文档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)