我在Octave中创建了一个单元格数组。有些列包含浮点数,有些列包含字符串。我可以使用以下命令按 strings 列(例如col#4)对单元格数组进行排序:
sortrows (mycellarray, 4);
但是如果我要排序的列是浮动的列,那么我收到此错误消息:
error: sort: only cell arrays of character strings may be sorted
有人知道如何通过浮动列对单元格数组进行排序吗?
答案 0 :(得分:6)
将具有浮点值的列转换为向量,对其进行排序并获取排序索引。然后,您可以将此索引应用于您的单元格数组。
mycellarray = {'a',1,0.5; 'b',2,0.1; 'c',3,4.5; 'd',4,-3.2};
vector2sort=cell2mat(mycellarray(:,3));
[~,idx] = sort(vector2sort)
mycellarraysorted = mycellarray(idx,:);
但是,在某些版本的Octave中,未定义波浪号~
运算符。在那种情况下:
vector2sort = mycellarray(:,3);
[dummy,idx] = sort(vector2sort);
mycellarraysorted = mycellarray(idx,:);