Matching only parts of two cell arrays

1 次查看(过去 30 天)
A= {'36450A107';'36467A107';'38067A107'}
B={'36467A'};
How can I find that the 2nd cell in A matches the first 6 characters of B?

采纳的回答

Azzi Abdelmalek
Azzi Abdelmalek 2013-7-14
编辑:Azzi Abdelmalek 2013-7-14
out=find(cellfun(@(x) strcmp(x(1:6),B),A))

更多回答(2 个)

Andrei Bobrov
Andrei Bobrov 2013-7-14
find(~cellfun('isempty',regexp(A,B)));

Chandrasekhar
Chandrasekhar 2013-7-14
for i = 1:length(A)
TF = findstr(char(B(1)),char(A(i)))
if(TF == 1)
disp(i)
end
end
  1 个评论
joseph Frank
joseph Frank 2013-7-14
this is not correct I tried it and it gave TF = 1 and 2 . I think you misunderstood the question. I want to find where the 1st 6 characters in A matches B . the 1st row definitely doesn't match nor the 3rd. the only row that matches is the 2nd one.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Simulink 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by