MATLAB利用映射将分类变量转为数值

% 要转换的分类变量列名
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型 不然无法符合映射的规则

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值