How to find the position of a specific characters containing in a string in a cell array
조회 수: 10 (최근 30일)
이전 댓글 표시
hello. i have a 136x39 cell array like this one
'Data Name' 'Timestamp' 360 370
'001-Day 1-RE-1' '24/07/2014 10:17:10' -738.803345332164 -734.184486898226
'001-Day 1-RW-1' '24/07/2014 10:17:37' -707.272295650121 -703.634423319119
'001-Day 1-LE-1' '24/07/2014 10:19:20' -744.635983922777 -740.346463517543
'001-Day 1-LW-1' '24/07/2014 10:19:39' -751.552763303339 -747.041101104821
and I want to find the positions of 'RE','RW','LE','LW'. I tried with the function [RW1, RW2]=find(strcmp('RW', array)); but got no results. I also tried [RW1, RW2]=find(strcmp('*RW*', Acdelta)); or strfind..
Any ideas?
Many thanks
댓글 수: 0
채택된 답변
Guillaume
2014년 10월 22일
Use either strfind four times, once for each pattern (RE, RW, LE, LW). Note that strfind (and strcmp) does not accept wildcards, or regexp
pos = regexp(array(:, 1), 'RE|RW|LE|LW', 'once');
Note that you can't pass the full cell array to strfind or regexp, since it contains elements that are not strings. Here, I just pass the first column.
Also, in your example, the position is always the same, so why do you want to find it?
댓글 수: 4
Guillaume
2014년 10월 22일
Ok, I'm still not very clear on what you're trying to do and whether or not your question is actually answered.
If you want the position and the value that follows the 'RE/RW/LE/LW', you can use a different regular expression:
[pos, valuestr] = regexp(array(:, 1), '(?:RE|RW|LE|LW)-(\d+)', 'start', 'tokens', 'once');
values = cellfun(@(v) str2double(v), valuestr, 'UniformOutput', false);
추가 답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Characters and Strings에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!