search for substring in cell array of strings

Hello,
I have this cell array of strings:
A = { 'This is how we do the shuffle', 'All night long there', 'In the club'};
I want to return the cell index where there is no 'the' in the cell array. I am using the following code:
str = 'the';
the _str = sprintf('\\<%s\\>',str);
index = strfind(A,the_str);
index_nothe = find(cellfun(@isempty,index));
however, I get an empty array for index. I put the '\\<%s\\>' to search for only the word 'the'.
I would like to return [2] for index, as that is the only cell that does not contain 'the'.
Can you tell me where I am going wrong?
Thanks.

回答 (1 件)

Azzi Abdelmalek
Azzi Abdelmalek 2015 年 6 月 3 日
編集済み: Azzi Abdelmalek 2015 年 6 月 3 日

2 投票

A = { 'This is how we do the shuffle', 'All night long there', 'In the club'}
idx=find(cellfun(@isempty,regexp(A,'the(\s)+','match')))

1 件のコメント

monkey_matlab
monkey_matlab 2015 年 6 月 3 日
Hello, Thanks for your response Azzi!
I actually put the sprintf('\\<%s\\>',str) command because str is a variable and will change depending on varying inputs. That is, str will not always be 'the', it may be someting else.
But can you tell me why my attempt is not giving me the desired result?
Thanks.

サインインしてコメントする。

カテゴリ

ヘルプ センター および File ExchangeCharacters and Strings についてさらに検索

タグ

質問済み:

2015 年 6 月 3 日

コメント済み:

2015 年 6 月 3 日

Community Treasure Hunt

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

Start Hunting!

Translated by