strfind when I have more than one row
1 Ansicht (letzte 30 Tage)
Ältere Kommentare anzeigen
K = STRFIND(TEXT,PATTERN)
I am trying to find Pattern in an array of many rows but I am receiving an error : ??? Error using ==> strfind Input strings must have one row
Is there any function taht would substitute strfind in this case?
1 Kommentar
Antworten (4)
Matt Fig
am 29 Jun. 2011
You have a couple of choices with STRFIND. You could loop over the rows, or pad the array with NANs (or other irrelevant value) then reshape to one long string. For example:
A = [1 2 3 4 5 6;7 6 5 6 3 2;1 2 3 4 5 6]
for ii = 1:size(A,1)
L{ii} = strfind(A(ii,:),[5 6]); % Preall if large A.
end
B = [A nan(size(A,1),1)];
strfind(reshape(B.',1,[]),[5 6])
0 Kommentare
Paulo Silva
am 29 Jun. 2011
a=['Congratulations'
'to Walter '
'for his 4000 '
'reputation '
'points ']
rc=[];
for r=1:size(a,1)
c=strfind(a(r,:),'Walter');
if ~isempty(c)
rc=[rc; r c]; %just in case the word appears multiple times
end
end
rc %first column is the row and second column is the column where the word is
1 Kommentar
Roland
am 29 Dez. 2011
This also does not work well. E.g. if one row has multiple matches this will cause an inconsistent dimensions error.
Teja Muppirala
am 30 Jun. 2011
STRFIND works on cells too:
a=['Congratulations'
'to Walter '
'for his 4000 '
'reputation '
'points '
'WalterWalterWal']
pat = 'Wal'
strfind(cellstr(a),pat)
1 Kommentar
Roland
am 29 Dez. 2011
This does not work well. E.g. if one row has multiple matches this will cause an inconsistent dimensions error.
Roland
am 29 Dez. 2011
This is a possible solution ... not perfect though:
%
% Look for a in b. Returns cell array of
% strfind results for each row.
%
% Usage: strfindmultirow(<searchdata>, <searchpattern>);
%
% e.g. if:
%
% a=['Congratulations'
% 'to Walter '
% 'for his 4000 '
% 'reputation '
% 'points ']
%
% rc = strfindmultirow(a, 'a');
%
% yields:
% rc = strfindmultirow(a, 'a')
% ans = [1x2 double] [5] [] [6] []
%
function rc = strfindmultirow(a, b)
rc={};
for r=1:size(a,1)
c=strfind(a(r,:), b);
rc{length(rc) + 1} = c;
end
0 Kommentare
Siehe auch
Kategorien
Mehr zu Data Type Conversion finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!