Effacer les filtres
Effacer les filtres

How can I delete the duplicate rows in cell based on a particular column?

2 vues (au cours des 30 derniers jours)
SM
SM le 26 Août 2020
Commenté : SM le 26 Août 2020
The input is:
A={[1 2 3] [2 3] [1 2 3];[2 5 8] [3 4] [1 2 3];[2 5 4] [2 3] [1 2 3];[1 2 5] [3 4] [1 2 3]};
based on the duplication in the 2nd column,the output will be:
B={[2 5 4] [2 3] [1 2 3];[1 2 5] [3 4] [1 2 3]};
How can I do that?
  2 commentaires
Matt J
Matt J le 26 Août 2020
Modifié(e) : Matt J le 26 Août 2020
How do you know which of the duplicates to keep? Why couldn't you keep the first two rows instead of the last two?
SM
SM le 26 Août 2020
That's really not matter for my case. I just want to delete the duplicate rows based on the 2nd column.

Connectez-vous pour commenter.

Réponse acceptée

Matt J
Matt J le 26 Août 2020
Modifié(e) : Matt J le 26 Août 2020
This assumes the second column always contains vectors of the same length, and also that you want to keep only the last occurence.
[~,idx]=unique(cell2mat(A(:,2)),'rows','last');
B=A(idx,:);

Plus de réponses (0)

Catégories

En savoir plus sur Logical dans Help Center et File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by