extract numbers or string after specific symbol from a text file

조회 수: 2 (최근 30일)
Binu
Binu 2020년 8월 6일
댓글: Binu 2020년 8월 9일
Hello
I have a set of text files with different attributes. Here is only three attributes of one file for example;
Location ID : 600
Field code : RNW
Sample interval : 60
The line number of these attributes are not the same for each file. How can I extract values after Location ID :, Field code :, and Sample interval : from all my text files if I put them in a loop.
Thank you

채택된 답변

Walter Roberson
Walter Roberson 2020년 8월 6일
편집: Walter Roberson 2020년 8월 6일
dinfo = dir('*.txt');
nfiles = length(dinfo);
filenames = fullfile({dinfo.folder}, {dinfo.name});
IDs = cell(nfiles,1);
FCs = cell(nfiles,1);
intervals = cell(nfiles,1);
for K = 1 : nfiles
filename = filenames{K};
S = fileread(filename);
parts = regexp(S, '(?<=Location ID\s*:\s*)(?<ID>\d+).*(?<=Field code\s*:\s*)(?<FC>\w+).*(?<=Sample interval\s*:\s*)(?<SI>\w+)', 'names');
IDs{K} = str2double({parts.ID});
FCs{K} = {parts.FC};
intervals{K} = str2double({parts.SI});
end
Note: this code does not assume that there is only one occurance of the information per file. It will find all of the occurance in each file, provided that the parts are all in the same order and none of the parts are missing.
If there is only ever one occurance then the code could be simplified a little.
  댓글 수: 3
Walter Roberson
Walter Roberson 2020년 8월 8일
dinfo = dir('*.txt');
nfiles = length(dinfo);
filenames = fullfile({dinfo.folder}, {dinfo.name});
IDs = zeros(nfiles,1);
FCs = cell(nfiles,1);
intervals = zeros(nfiles,1);
for K = 1 : nfiles
filename = filenames{K};
S = fileread(filename);
parts = regexp(S, '(?<=Location ID\s*:\s*)(?<ID>\d+).*(?<=Field code\s*:\s*)(?<FC>\w+).*(?<=Sample interval\s*:\s*)(?<SI>\w+)', 'names', 'once');
IDs(K) = str2double(parts.ID);
FCs{K} = parts.FC;
intervals(K) = str2double(parts.SI);
end
Binu
Binu 2020년 8월 9일
Thanks Walter . Appreciate your help.

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

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Text Data Preparation에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by