How to extract multiple numbers with regexp?
31 ビュー (過去 30 日間)
古いコメントを表示
I am trying to pull the ID from the following string.
'blah String XX blah'
where XX is the number that could be anything from 0 - 9999. I have tried the regular expression below but this only works for 0 - 9. Any ideas?
[aa,bb] = regexp(sss,'String (\d+)')
1 件のコメント
採用された回答
Walter Roberson
2016 年 2 月 16 日
id = regexp(sss, '(?<=String\s+)(\d+)', 'match', 'once');
The result will be a cell array of string containing the matched string
If you want it more directly then
id = regexprep(sss, '(.*?String\s+)(\d+)(.*)', '$2', 'once');
The result would be a string directly.
The first version, the regexp version, is looking for digits proceeded by 'String' with the 'String' part marked up to indicate it is not to form part of the match.
The second version, the regexprep version, is matching on beginning of line to the first occurrence of 'String' as one group, matching on the digits as a second group, and matching to the end of the line as a third group, and is replacing the three matches with the content of the second group, thus effectively throwing away everything before and after the digits.
その他の回答 (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!