Exporting matched lines from a text file
1 visualización (últimos 30 días)
Mostrar comentarios más antiguos
jgillis16
el 12 de Ag. de 2015
I am trying to export the lines in a text file that contain '~' in column 8 to another text file. I have written the code below:
content = fileread('mwithrm21.txt');
linestocopy = regexp(content, '^([^|]*\|){8}~\.*$', 'match', 'dotexceptnewline', 'lineanchors');
newfile = fopen('LFunclassified.txt', 'wt');
fprintf(newfile, strjoin(linestocopy, '\n'));
fclose(newfile);
I don't understand why it is returning a blank file as the export. Most likely a problem in the linestocopy command, but I don't know what else to modify. My file is also attached.
0 comentarios
Respuesta aceptada
Cedric
el 12 de Ag. de 2015
Editada: Cedric
el 12 de Ag. de 2015
Because your file contains no new line characters (\n = ASCII 10) but only carriage return characters (\r = ASCII 13). After you read the file, convert \r to \n for testing:
content = fileread( 'mwithrm21.txt' ) ;
content(content==13) = 10 ;
Then you should work on the code that produces the txt file if you can, and use \n. Finally, as Per mentions, you have 8 columns so you have max 7 separators.
Finally, you may be able to simplify your pattern, for something like
'^(.*?\|){7}~.*$'
but you'll have to test it.
Más respuestas (0)
Ver también
Categorías
Más información sobre Low-Level File I/O en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!