% 要转换的分类变量列名
categoricalVars = ['小区名字', '朝向',"楼层","装修","区域"]; % 这里列出所有需要转换的分类变量名
categoricalVarsdata = table(data.('小区名字'), data.('朝向'),data.("楼层"),data.("装修"),data.("区域"));
categoricalVarsdata.Var1 = string(categoricalVarsdata.Var1);
categoricalVarsdata.Var2 = string(categoricalVarsdata.Var2);
categoricalVarsdata.Var3 = string(categoricalVarsdata.Var3);
categoricalVarsdata.Var4 = string(categoricalVarsdata.Var4);
categoricalVarsdata.Var5 = string(categoricalVarsdata.Var5)
categoricalVarsdata.Properties.VariableNames = ['小区名字', '朝向',"楼层","装修","区域"];
categoricalVarsdata
% 创建一个空的 cell 数组来存储转换后的数值数据
% numericData = cell(size(categoricalVarsdata, 1), length(categoricalVars));
numericData = cell(size(categoricalVarsdata, 1), length(categoricalVars));
% 遍历每个分类变量
for i = 1:length(categoricalVars)
varName = categoricalVars{i};
% 提取分类变量的唯一值
categories = unique(categoricalVarsdata.(varName));
% 初始化一个映射,将每个唯一值映射到一个数字
categoryMap = containers.Map(categories, 1:length(categories));
% 遍历数据表中的每个元素,并应用映射
for j = 1:size(categoricalVarsdata, 1)
% 将分类变量的值转换为数字
numericData{j, i}= categoryMap(categoricalVarsdata{j, varName});
end
end
numericData
% 将转换后的数值数据转换为矩阵
numericMatrix = cell2mat(numericData);
numericMatrix_categorical = categorical(numericMatrix )
% 打印转换后的数值矩阵
disp(numericMatrix)
需要注意的是在这里 要用大括号 确保获得的键为String型 不然无法符合映射的规则