Filter löschen
Filter löschen

Edit user input

1 Ansicht (letzte 30 Tage)
Raldi
Raldi am 1 Dez. 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?

Akzeptierte Antwort

Walter Roberson
Walter Roberson am 1 Dez. 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 Kommentar
Raldi
Raldi am 1 Dez. 2011
Thanks Walter. This is way much better than what i came up with

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Raldi
Raldi am 2 Dez. 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 Kommentar
Walter Roberson
Walter Roberson am 2 Dez. 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.

Melden Sie sich an, um zu kommentieren.

Community Treasure Hunt

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

Start Hunting!

Translated by