find unique array cell with 2 field

7 次查看(过去 30 天)
load('matlab_f.mat')
f
f = 4x2 cell array
{'a'} {'1'} {'a'} {'1'} {'c'} {'2'} {'c'} {'1'}
i want to find row equal
f(1.:) and f(2,:) are equal
f(3.:) and f(4,:) are not equal

采纳的回答

Matt J
Matt J 2024-10-13
>> findgroups(f(:,1),f(:,2))
ans =
1
1
3
2
  4 个评论
Luca Re
Luca Re 2024-10-13
thank but if i want to delete duplicate..can i do it?
can I search for the same pairs and delete one of these or is there a faster method
Matt J
Matt J 2024-10-13
编辑:Matt J 2024-10-13
I demonstrated how to do that in my other answer.
Ultimately, you should probably convert your data and leave it in table form. The things you are asking are very readily done with the data in that form.

请先登录,再进行评论。

更多回答(2 个)

Matt J
Matt J 2024-10-13
编辑:Matt J 2024-10-13
load('matlab_f.mat')
table2cell(unique(cell2table(f),'rows'))
ans = 3x2 cell array
{'a'} {'1'} {'c'} {'1'} {'c'} {'2'}

Sameer
Sameer 2024-10-13
编辑:Sameer 2024-10-13
Hi Luca
To compare rows of a cell array and determine if they are equal, you can use the "isequal" function.
Here's how you can do it:
load('matlab_f.mat')
% Check if the first and second rows are equal
if isequal(f(1,:), f(2,:))
disp('f(1,:) and f(2,:) are equal');
else
disp('f(1,:) and f(2,:) are not equal');
end
f(1,:) and f(2,:) are equal
% Check if the third and fourth rows are equal
if isequal(f(3,:), f(4,:))
disp('f(3,:) and f(4,:) are equal');
else
disp('f(3,:) and f(4,:) are not equal');
end
f(3,:) and f(4,:) are not equal
Please refer to the below MathWorks documentation link:
Hope this helps!

类别

Help CenterFile Exchange 中查找有关 Shifting and Sorting Matrices 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by