フィルターのクリア

Reuse parts of the matching expression as replace string

4 ビュー (過去 30 日間)
Léon
Léon 2013 年 11 月 7 日
編集済み: Adam Danz 2020 年 8 月 29 日
Hello,
I stuck in the usage of the regexprep() function and hope sb. can point me to the correct solution.
myarray = {'ABC 500mm';'DEF 3mm';'GHI 0.1mm'};
output = cellfun(@(myarray) regexprep(myarray,'\d*+mm','${regexp($0,''\d*'',''match'')}'),myarray, 'UniformOutput',false);
This 'solution' sadly produces an error as it states that the replacement string does not output a real string to use here. What I try to do is pretty simple - erase all occurrences of 'mm' when found after a number.
Many thanks!

採用された回答

Sean de Wolski
Sean de Wolski 2013 年 11 月 7 日
編集済み: Sean de Wolski 2013 年 11 月 7 日
myarray = {'ABC 500mm';'DEF 3mm';'GHI 0.1mm';'3mmm'};
regexprep(myarray,'(\d)mm','$1')
Explained:
capture a token () for any digit \d followed by mm. Replace whole expression with the token (i.e. the digit).
Also the regexp* family of functions can work on cellstr arrays :)
  2 件のコメント
Léon
Léon 2013 年 11 月 7 日
Hey thx! :)
Adam Danz
Adam Danz 2020 年 8 月 29 日
編集済み: Adam Danz 2020 年 8 月 29 日
Nice explanation, Sean de Wolski!
Regular expressions are one of those things that you could use for years and learn something new every time you put one together.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeCharacters and Strings についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by