我使用 textscan 导入了 2 列数据。数据如下所示,其中 U 是undetect,D 是detect
mydata=
.51 U
.57 D
.48 U
.47 D
my data = [4x1 double] [4x1 char]
我想按第一列对数据进行排序,所以数据看起来像这样
.47 D
.48 U
.51 U
.57 D
我想保留单元格结构,以便以下分配逻辑值的命令仍然适用:
c = zeros(size(mydata,1),1); % preallocate empty matrix
c = mydata{2} == 'U';
for i = 1:size(mydata,1)
curValue = mydata{i,2};
data{i,3} = ~isempty(curValue) && ischar(curValue) && strcmp(curValue ,'U');
end
我阅读了有关 sortrows 的内容,但该函数用于对仅包含数字的矩阵进行排序。
有没有人有对数字和字符混合的数组进行排序的解决方案。
最佳答案
您可以 SORT通过一个向量并将排序索引应用于另一个向量。
[mydata{1},idx] = sort(mydata{1});
mydata{2} = mydata{2}(idx);
关于matlab - 在 Matlab 中对列进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8620185/