match a word/string
이전 댓글 표시
Hi all. I have a file, in which the first column which contains 27k rows of words/strings. (eg:GDD51). I need to search a particular string and create another file with all values corresponding to the second column in that file. The problem is, i can't search for a string. It says error! Can someone help me. this is the code i used:
x=0;
for i=1:27099
if file(i,1)=='GDD51
x=x+1;
newfile(x,1)=file(i,2);
end
end
And i get this error: Undefined function 'eq' for input arguments of type 'table'. Please help,Thanks
댓글 수: 3
Geoff Hayes
2014년 11월 26일
Bharat - please post the code that you are using to read the data from file, and search for the string that you are interested in. As well, since there is an error, please post the full error message (all text in red). Just update/edit your above question with thus additional information.
Bharat
2014년 11월 27일
Image Analyst
2014년 11월 27일
편집: Image Analyst
2014년 11월 27일
Well you didn't have a closing apostrophe on the "if" line. But why not just use my answer?
채택된 답변
추가 답변 (1개)
Image Analyst
2014년 11월 26일
Try this:
% Create sample data
cellArrayOfStrings = {'No Match this index', 'GDD51', 'no match here either'};
% Find index where cell contents = 'GDD51'
index = ismember(cellArrayOfStrings, 'GDD51')
댓글 수: 1
Image Analyst
2014년 11월 27일
Regarding your edit for making a file of the second column where it's true
fid = fopen(filename, 'wt');
for k = 1 : length(index)
if index(k)
fprintf(fid, '%s\n', cellArrayOfStrings{k});
end
end
fclose(fid);
카테고리
도움말 센터 및 File Exchange에서 Characters and Strings에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!