Remove a specific string from a cell matrix

8 次查看(过去 30 天)
Hello,
I have a question. I have a cell matrix 200x1 with the following format.
Temperature 10
Temperature 10
Temperature 25
Temperature 30
........................
Temperature 150.
I would like to use a command which will "remove" the string "Temperature".
Does anybody knows which command should I use to make it?

采纳的回答

Adam Danz
Adam Danz 2019-10-3
编辑:Adam Danz 2019-10-3
Option 1: strrep() to replace 'Temperature ' with empty
C = {'Temperature 10';'Temperature 10';'Temperature 25';'Temperature 30'};
Ctrim = strrep(C,'Temperature ','') %cell array of chars containing only the numbers
Cnum = str2double(Ctrim); %vector of the numbers of class double.
Option 2: regexp() to extract the numeric characters
Ctrim = regexp(C,'\d+','match','once');
Cnum = ... %see above
Option 1 is faster.
  2 个评论
Adam Danz
Adam Danz 2019-10-3
Glad I could help!
BTW, the first solution, using strrep, is ~3.6 x faster (comparing median speeds using tic/toc across 100k iterations, each).

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Matrices and Arrays 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by