searching cell arrays

I want to find the index of a cell array that contains a specific string, but the search and find functions don't take cell arrays as arguments. How do I return the cell number that contains the string?

 採用された回答

Walter Roberson
Walter Roberson 2012 年 2 月 24 日

1 投票

Should the cell exactly match the specific string? If so then use ismember().
Should the cell member start with the specific string? If so then cellfun() and strncmp()
Should the cell member contain the specific string as a substring somewhere in it? If so then cellfun() and strfind() and isempty()
The matching process on a cellstr can also be done by regexp(); you might need to cellfun() isempty() to determine the logical result for each entry. It is, though, well suited to returning substring locations, and if you have time it would be worth reviewing regexp() as a serious possibility.

1 件のコメント

Jan
Jan 2012 年 2 月 24 日
STRNCMP operates on cell strings directly, so you do not need CELLFUN.

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

その他の回答 (2 件)

Jan
Jan 2012 年 2 月 24 日

1 投票

C = {'abc', 'hello', '81'}
strcmp(C, 'hello')
% >> 0 1 0
find(strcmpi(C, 'HELLO'))
% >> 2
the cyclist
the cyclist 2012 年 2 月 24 日

1 投票

Here's one way, similar to Jan's:
C = {'abc', 'hello', '81'};
find(ismember(C,'hello'))

カテゴリ

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

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by