how to open an external text file, identify two strings and save the lines of the text file where the two strings appear

2 views (last 30 days)
Hi,
I would like to open an external text file, identify two strings, for example "Pattern1" and "Pattern2" and save in two variables, line1 and line2, the number of the line of the text file where "Pattern1" and "Pattern2". I am attaching the text file. In this example line1=12 and line2=24
I thank you in advance,
Best regards,
Hugo

Accepted Answer

Mathieu NOE
Mathieu NOE on 12 Mar 2021
hello Hugo
see below
Filename = 'sample_text.txt';
[Pattern1_line, Pattern2_line] = extract_data(Filename);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [Pattern1_line, Pattern2_line] = extract_data(Filename)
fid = fopen(Filename);
tline = fgetl(fid);
% initialization
k = 0;
p = 0;
q = 0;
Pattern1_line = 0;
Pattern2_line = 0;
while ischar(tline)
k = k+1; % loop over line index
% retrieve line Date/Time
if contains(lower(tline),'pattern1') % lower make matlab not case sensitive
Pattern1_line = k;
end
% retrieve line Date/Time
if contains(lower(tline),'pattern2') % lower make matlab not case sensitive
Pattern2_line = k;
end
tline = fgetl(fid);
end
fclose(fid);
end

More Answers (2)

Jan
Jan on 29 Jun 2021
S = fileread('sample_text.txt');
C = strsplit(S, '\n');
Pattern1_line = find(contains(C, 'Pattern1', 'IgnoreCase', true));
Pattern2_line = find(contains(C, 'Pattern2', 'IgnoreCase', true));

Hugo
Hugo on 12 Mar 2021
Dear Mr. Mathieu,
Thank you for your help. Unfortunately, your solution does not work on my end. Do you have other suggestions?
  3 Comments
Hugo
Hugo on 15 Mar 2021
Hi,
I don't get any error. I just don't get any output file with the data I want to filter. Do you have any other suggestion?
Mathieu NOE
Mathieu NOE on 16 Mar 2021
hello
you should get the two variables in your workspace
that's what the line :
[Pattern1_line, Pattern2_line] = extract_data(Filename);
does.
proof :
I got in my workspace :
Pattern1_line = 12
Pattern2_line = 24
Now if you want to save it in a output file, I didn't code it but I suppose you know how to do it

Sign in to comment.

Categories

Find more on Data Import and Export in Help Center and File Exchange

Products


Release

R2018b

Community Treasure Hunt

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

Start Hunting!