为什么在matlab 2022中执行以下代码时,daxiaobi表是空的?% 读取Shuju表格中的数据并保存胸径数据到xiongj表格 shuju = readtable('Shuju.xlsx'); xiongj = table(shuju{:, 4}, 'VariableNames', {'xiongj'}); % 获取中心树的胸径数据 writetable(xiongj, 'xiongj.xlsx'); % 读取zyshu表格,并依次读取最近的4棵树的胸径数据到xiongj表格 zyshu = readtable('zyshu.xlsx'); for i = 1:size(zyshu, 1) for j = 2:5 idx = zyshu{i, j}; xiongj{i, j} = shuju{idx, 4}; end end writetable(xiongj, 'xiongj.xlsx'); % 遍历xiongj表格,比较每一行的胸径数据,并计算比较结果的平均值 daxiaobi = zeros(size(xiongj,1),2);%创建一个和xiongj一样大小的数组,用来保存结果 sum_val=0; for i = 1:size(xiongj, 1) row_val = xiongj{i, 2:end}; %取要比较的各列的值,xiongj{i, 2:end}是一个行向量 n = length(row_val); %取列的个数 if all(xiongj{i, 1} <row_val) %判断当前行的第一个元素是否小于row_val向量中的元素,若小于则计数器sum_val加1 sum_val=sum_val+1; end daxiaobi{i,2} = sum_val / n; end % 保存daxiaobi表格 writetable(daxiaobi, 'daxiaobi.xlsx'); % 在命令行窗口输出daxiaobi表格 disp(daxiaobi);
时间: 2024-03-11 21:43:46 浏览: 106
svm.rar_SVM_svm matlab
在Matlab 2022中执行该代码时,daxiaobi表格为空是因为在第14行中,`xiongj`表格是先写入了文件'xiongj.xlsx',但是在第19行时重新从文件中读取了`xiongj`表格,这时`xiongj`表格已经被修改了,导致第27行中`daxiaobi`表格的计算出现问题。解决方法是在第19行中不再从文件中读取`xiongj`表格,而是直接使用第14行中的`xiongj`表格,即将第19行改为`for i = 1:size(xiongj, 1)`。另外,在第25行中,`daxiaobi`表格的列数定义为2,但是只有第二列有值,应该改为将计算结果赋值给第一列,即将第25行改为`daxiaobi{i,1} = sum_val / n;`。
阅读全文