Edit user input

4 views (last 30 days)
Raldi
Raldi on 1 Dec 2011
Lets say i have something like s='12s+34a+45'; Is there a way so i can only store the numbers that are in front of the letter s and store it to an array?

Accepted Answer

Walter Roberson
Walter Roberson on 1 Dec 2011
numstrs = regexp(TheString, '-?\d+(?=\s*s)', 'match');
and convert the resulting cells strings in to numeric forms.
The (?=\s*s) part is regexp-ese for "the expression after the '=' until the ')' must be matched in the input right after whatever was matched before this, but do not return this part as part of the match". Another way of phrasing this is that it "looks ahead" for the pattern but does not include it as part of what is matched.
\s*s stands for "any number of whitespace characters (including none), followed by the letter 's')
  1 Comment
Raldi
Raldi on 1 Dec 2011
Thanks Walter. This is way much better than what i came up with

Sign in to comment.

More Answers (1)

Raldi
Raldi on 2 Dec 2011
There is a problem though with this code. It seems it wont recognise lets say 0.5*s but it will only take number 5, so i need a way to exclude '.' from regexp.
  1 Comment
Walter Roberson
Walter Roberson on 2 Dec 2011
If you define exactly which patterns of characters are to be accepted, then a regexp() expression can be constructed. The pattern to match a general floating point number that might be in exponential form gets quite complicated though.
numstrs = regexp(TheString, '-?(?:(?:\d*\.)?\d+|\d+\.)(?=\s*s)', 'match')
The above does not recognize exponentials, but it does recognize
optional leading minus sign, recognizes digits followed by 's', recognizes digits followed by '.s', recognizes digits followed by '.' followed by digits followed by 's', recognizes '.' followed by digits followed by 's', while still refusing '.s' alone with no digits. Oh yes, optional spaces are permitted before the 's' itself.

Sign in to comment.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!