How do I find specific values in a .txt file?
21 ビュー (過去 30 日間)
古いコメントを表示
Hello everybody,
I have a .txt file. And I need to find the key words in the text then pick the value next to the key words. Here is one part of this text file:
%% Define the target filter
freq_step = 0.2; % Frequency step (GHz)
lowest_freq = 20; % Lowest frequency of the whole frequency band (GHz)
mid_freq = 33; % Middle frequency of the passband (GHz)
highest_freq = 45; % Highest frequency of the whole frequency band (GHz)
pass_s11_max_tgt = -10; % Target maximum S11 in the passband (dB)
pass_s11_min_tgt = -15; % Target minimum S11 in the passband (dB)
pass_s21_tgt = -1; % Target S21 in the passband (dB)
stop_s11_tgt = -1; % Target S11 in the stopband (dB)
stop_s21_max_tgt = -15; % Target maximum S21 in the stopband (dB)
stop_s21_min_tgt = -25; % Target minimum S21 in the stopband (dB)
I need the values after "freq_step = ", "lowest_freq = ", "highest_freq = ". Could anyone help me with that?
0 件のコメント
採用された回答
Mathieu NOE
2021 年 2 月 1 日
hello
this code will extract the searched items and stote them in a table (taht you can save to excel if needed)
hope it helps
lines = readlines('Document1.txt');
for ci =1:numel(lines)
line_str = extractBefore(lines(ci),'='); % extract question number (with double quote)
if strfind(line_str,'freq_step')
Value1 = str2num(extractBetween(lines(ci),'=',';')); % extract values and convert string to numerical
elseif strfind(line_str,'lowest_freq')
Value2 = str2num(extractBetween(lines(ci),'=',';')); % extract values and convert string to numerical
elseif strfind(line_str,'highest_freq')
Value3 = str2num(extractBetween(lines(ci),'=',';')); % extract values and convert string to numerical
end
end
A = [Value1' Value2' Value3'];
T = array2table(A, 'VariableNames',{'freq step','lowest freq','highest freq'})
writetable(T,'test.xlsx')
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Data Import and Export についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!