find a cell array of strings in another cell array of strings
이전 댓글 표시
I have two cell array of strings, say A and B. I would like to find all cells in B, in which cells of A are occurred! for example:
A={'aa';'a a';'b a'}
B={'s a';'a a';'ll';'a a';'b a';'h f'}
Here 'a a' happened twice in B, and also 'b a' happened once and 'aa' never happened. Then I would like to delete those cells, so I will have:
B={'s a';'ll';'h f'}
So, I have to consider the repetition of strings like 'a a'.
Does anyone know how to do this?
Many thanks
답변 (2개)
Guillaume
2016년 4월 14일
ismember is the function that tells you if elements of a set are found in another set.
A = {'aa'; 'a a'; 'b a'}
B = {'s a'; 'a a'; 'll'; 'a a'; 'b a'; 'h f'}
%find which cells of A are in B
isAinB = ismember(A, B);
fprintf('''%s'' of A was found in B\n', A{isAinB});
%find which cells of B are in A and delete them
isBinA = ismember(B, A);
B(isBinA) = []
Jos (10584)
2016년 4월 14일
So you want the keep the elements in B that are not in A. This is known is the difference in sets, implemented in matlab like this
A = {'aa' ; 'a a' ; 'b a'}
B = {'s a' ; 'a a' ; 'll' ; 'a a' ; 'b a' ; 'h f'}
OUT = setdiff(B,A)
댓글 수: 2
Guillaume
2016년 4월 14일
Then use ismember as per my answer.
카테고리
도움말 센터 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!