我尝试在我的单元格中找到必须在其名称中包含“HA”的数组。我在这里找到了一个功能,但它对我的问题不起作用。 我的手机看起来像这样:
'HA1' 'HA1' 'HA1' 'HA1' 'HA1'
'HA2' 'HA2' 'HA2' 'HA2' 'HA2'
'HA3' 'HA3' 'HA3' 'HA3' 'HA3'
'HA4' 'HA4' 'HA4' 'HA4' 'HA4'
'HA5' 'HA5' 'HA5' 'HA5' 'HA5'
'HA6' 'HA6' 'HA6' 'HA6' 'HA6'
'HA7' 'HA7' 'HA7' 'HA7' 'HA7'
'HA8' 'WA1' 'WA1' 'WA1' 'WA1'
'HA9' 'WA2' 'WA2' 'WA2' 'WA2'
'HA10' 'WA3' 'WA3' 'WA3' 'WA3'
'HA11' 'WA4' 'WA4' 'WA4' 'WA4'
'DA1' 'WA5' 'WA5' 'WA5' 'WA5'
'DA2' [] [] [] 'WA6'
'DA3' [] [] [] 'WA7'
'DA4' [] [] [] 'WA8'
'DA5' [] [] [] 'WA9'
'DA6' [] [] [] 'WA10'
[] [] [] [] 'WA11'
[] [] [] [] 'WA12'
我试过这个功能:
x = 'HA';
y = cellArray;
substrfind = @(x,y) ~cellfun(@isempty,strfind(y,x));
logicalArray = substrfind(x,y);
我应该得到一个逻辑数组作为输出,这对我的问题非常有用。但相反,我收到此错误消息:
“如果任何输入参数是单元格数组,则第一个必须是字符串的单元格数组,第二个必须是字符数组。”
我不明白错误是什么,因为第一个输入y是一个单元格数组,第二个输入是一个字符。
我希望你们能解决我的问题! 谢谢你的期待! 最好的问候
答案 0 :(得分:8)
假设C
是您的单元格数组。然后一种方法来做你想做的事情:
>> C(cellfun('isempty', C)) = {''};
>> logicalArray = ~cellfun('isempty', strfind(C, 'HA'))
strfind
不接受某些值不是字符串的单元格数组。您的单元格数组恰好有空值,但错误类型 - []
为double
,而不是char
。这就是你得到这个错误的原因。
因此,我只需使用空字符double
)替换每个空''
,然后使用strfind
。
解决此问题的另一种方法:
>> logicalArray = cellfun(@(x)~isempty(strfind(x,'HA')), C)
但这要慢得多。