How to extract every repeated sequence line from text file using MATLAB
2 次查看(过去 30 天)
显示 更早的评论
Time(sec) 20.30
Type 1
Svid slew power used
12. 0.33 -36dbm y
10 .38. -40dbm N
08. 0.40 -30dbm Y
Time(sec) 20.40
Type 2
Svid slew power used
12. 0.46. -38dbm Y
06. 0.50. -32dbm Y
02. 0.42. -30dbm N
sequence repeats....
How to pull out all Type-1 SVID 12 row which is repeating (say after 10 line). How can I save it to new file so that I can manipulate for further processing. Any help is highly appreciated! POKA
回答(1 个)
KSSV
2017-8-3
You can get the indices of your string Type 1 and Svid1 using the below code:
fid = fopen('data.txt') ;
S = textscan(fid,'%s','delimiter','\n') ;
S = S{1} ;
fclose(fid) ;
%%gEt string Type 1
idx1 = find(not(cellfun('isempty', strfind(S, 'Type 1')))); % lower then 2016b
% idx1 = contains(S,'Type 1') ;
% idx1 = find(idx==1) ;
% GEt string Svid
idx2 = find(not(cellfun('isempty', strfind(S, 'Svid'))));
Once you have indices you can extract what you want..
9 个评论
Walter Roberson
2017-8-4
By default, \r is 'whitespace' for textscan() but strsplit() treats it as just another character.
strsplit() calls regexp(). You can go more directly:
S = sprintf( '%s\r\n%s', 'A','B' );
cac = regexp( S, '\r?\n', 'split');
per isakson
2017-8-4
It's more to it
>> cac = textscan( sprintf( '%s\r\n%s', 'A','B' ), '%s%s', ...
'Delimiter','\n', 'Whitespace','' )
cac =
{1x1 cell} {1x1 cell}
>> double(cac{1}{:})
ans =
65
>>
另请参阅
类别
在 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!