How to find the position of a specific characters containing in a string in a cell array
8 次查看(过去 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!