how to search and delete the nth ocurance of a text in a text file
1 次查看(过去 30 天)
显示 更早的评论
Hallo,
I have a text file 'test.txt' . The contents of test file is as follows.
Tim is Home
John is happy
Sara is funny
Kevin is at work
John is happy
Cat and Dog
I want to open the test.txt file and delete the 'nth' occurance of 'John is happy '. I have attached the text file too. Thanks in advance.
eg. I want to delete the line with ' n th 'occurance.
so It can be 1st occurance
or 2nd Occurance.. etc
Regards,
Jaffrey
0 个评论
采纳的回答
madhan ravi
2019-7-17
s = fileread('test.txt');
v = regexp(s,'\n','split');
z = regexprep(s,'John is happy','',2) % 2 denotes the nth occurence
dlmwrite('sample.txt',z,'delimiter','')
4 个评论
更多回答(2 个)
Adam Danz
2019-7-17
编辑:Adam Danz
2019-7-17
The question is unclear whether the goal is to remove the 2nd line of text or to remove the line(s) with "John is happy". The block below shows both interpretations.
% Import text
opts = delimitedTextImportOptions("NumVariables", 1);
opts.VariableNames = "txt";
test = readtable("C:\Users\adanz\Documents\MATLAB\savehere\matlabCentralDocs_trash\test.txt", opts);
test = table2array(test);
% Delete 2nd line
test(2) = [];
% - OR -
% Delete lines that match "John is happy"
idx = strcmpi(test, 'John is happy');
test(idx) = [];
% - OR -
% delete nth occurance of "John is happy"
n = 2;
idx = strcmpi(test, 'John is happy');
test(max(find(idx,n))) = [];
% Write to txt file
fid = fopen('test2.txt','wt');
fprintf(fid,'%s\n',test{:});
fclose(fid);
3 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Environment and Settings 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!