extract numbers or string after specific symbol from a text file

4 ビュー (過去 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 Center および File ExchangeMATLAB Report Generator についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by