Ответы:
Я думаю, следующий код может помочь:
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'}
ind=find(ismember(strs,'KU'))
Это возвращает
ans =
2
>> strs = {'HA' 'KU' 'LA' 'MA' 'TATA'};
>> tic; ind=find(ismember(strs,'KU')); toc
Истекшее время 0,001976 секунды.
>> tic; find(strcmp('KU', strs)); toc
Прошедшее время 0,000014 секунды.
ТАК, явно strcmp('KU', strs)
занимает гораздо меньше времени, чемismember(strs,'KU')
С 2011a рекомендуемый способ:
booleanIndex = strcmp('KU', strs)
Если вы хотите получить целочисленный индекс (который вам часто не нужен), вы можете использовать:
integerIndex = find(booleanIndex);
strfind
устарел, поэтому постарайтесь не использовать его.
Я вижу, что все упустили самый важный недостаток в вашем коде:
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'}
должно быть:
strs = {'HA' 'KU' 'NA' 'MA' 'TATA'}
или
strs = {'HAKUNA' 'MATATA'}
Теперь, если вы будете использовать
ind=find(ismember(strs,'KU'))
Вам не о чем беспокоиться :).
Другие ответы, вероятно, в этом случае проще, но для полноты я подумал, что добавлю использование cellfun с анонимной функцией.
indices = find(cellfun(@(x) strcmp(x,'KU'), strs))
который имеет то преимущество, что вы можете легко сделать его нечувствительным к регистру или использовать его в тех случаях, когда у вас есть массив ячеек структур:
indices = find(cellfun(@(x) strcmpi(x.stringfield,'KU'), strs))
Самый короткий код:
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'};
[~,ind]=ismember('KU', strs)
Но возвращает только первую позицию в strs
. Если элемент не найден, то ind=0
.
Функции strcmp и strcmpi - самый простой способ сделать это. Они ищут в массивах.
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'}
ix = find(strcmp(strs, 'KU'))
ты пробовал
indices = Find(strs, 'KU')
см. ссылку
альтернативно,
indices = strfind(strs, 'KU');
тоже должно работать, если я не ошибаюсь.