错误使用 cell/ismember 类 double 的输入 A 和类 cell 的输入 B 必须为字符向量元胞数组,除非其中某个输入为字符向量。 出错 untitled4 (第 28 行) [~, index] = ismember(data0{i,1}, C1);
时间: 2024-04-21 21:28:49 浏览: 146
'ismember' 用于具有各种数据类型的元胞数组:'cellismember' 是一个对具有各种数据类型的元胞数组执行 'ismember' 的函数-matlab开发
这个错误提示是因为 ismember 函数要求输入的两个参数必须具有相同的类型。在这里,data0{i,1}是一个cell,而C1是一个cell数组,两者类型不同。因此,你需要将data0中的cell转换为字符向量,可以使用cellstr函数来实现。修改后的代码如下:
%% 2.导入数据
data0 = readtable('数据1.xlsx', 'VariableNamingRule', 'preserve');
%% 定义分类列表
C1 = {'优', '良', '轻度污染', '中度污染', '重度污染', '严重污染'};
C2 = [1,2,3,4,5,6];
%% 将数据转换为数值型
data1 = zeros(height(data0), 1);
for i = 1:height(data0)
[~, index] = ismember(cellstr(data0{i,1}), C1);
data1(i) = C2(index);
end
修改后的代码中,使用 cellstr 函数将 data0{i,1} 转换为字符向量,这样就可以与 C1 数组中的字符向量进行匹配了。
阅读全文