Extract float from a filename

조회 수: 1 (최근 30일)
K3iTH
K3iTH 2022년 2월 24일
댓글: K3iTH 2022년 2월 24일
Hi all,
I have a list of files in a directory with a name of "time_ xx" where xx is number (for e.g 0.20, 0.41, 0.61, 0.82,...) the number is not does not have a fixed expression. I want like to extract these number and used it for calculation later.
May I know what function can I used to extract the number from a filename without extension?
Thank you.

채택된 답변

DGM
DGM 2022년 2월 24일
편집: DGM 2022년 2월 24일
Well I guess this is one way. There are probably more elegant ways of unpacking the nested cell array and converting to numeric, but this is how I did it.
names = {'time_0.709'
'time_5.61'
'time_0.2081'
'time_45.027'
'time_90'};
filenums = str2double(regexprep(names,'.*_(?=(\d*\.*)+$)',''))
filenums = 5×1
0.7090 5.6100 0.2081 45.0270 90.0000
This looks for any number between an underscore and the end of each name. The filename prefix is ignored except for the underscore.
I guess if you wanted rely on the prefix, you could alternatively just do:
names = {'time_0.709'
'time_5.61'
'time_0.2081'
'time_45.027'
'time_90'};
filenums = str2double(strrep(names,'time_',''))
filenums = 5×1
0.7090 5.6100 0.2081 45.0270 90.0000
  댓글 수: 1
K3iTH
K3iTH 2022년 2월 24일
Hi DGM,
Thank you for you help. Both method is very useful. Persoanlly, I seldom use "regexprep" but the second method "strrep" is fast and direct.
Once again, thank you so much!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Characters and Strings에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by