Effacer les filtres
Effacer les filtres

write multiple line of text into a text file

77 vues (au cours des 30 derniers jours)
Ali
Ali le 3 Août 2017
Commenté : Walter Roberson le 5 Août 2017
Simple question; I have this variable which I want easily write to a text file (it can be a hundred of lines, I just cut it into 4 to fit here)
app.DCMtxt.Value
ans =
4×1 cell array
'3 Message(s) transmitted '
''
' ws BUS ID Rx Node DLC Cycle Extended'
' ______ ___ ____ __ ____ ___ _____ ________'
  4 commentaires
Ali
Ali le 4 Août 2017
Modifié(e) : Ali le 4 Août 2017
Thanks for the replies. Per, it does not write to the file. I also get: Warning: Escaped character '\s' is not valid. See 'doc sprintf' for supported special characters. I see it reads it line by line, nice!
Ali
Ali le 4 Août 2017
looks like Per's answer had a typo and otherwise working well, so I'm reposting it with minor change as an answer
fid = fopen('output.txt','w');
for jj = 1 : size( app.DCMtxt.Value, 1 )
fprintf( fid, '%s\n', app.DCMtxt.Value{jj,1} );
end
fclose(fid);

Connectez-vous pour commenter.

Réponse acceptée

Walter Roberson
Walter Roberson le 4 Août 2017
fid = fopen('output.txt','w');
fprintf(fid, '%s\n',app.DCMtxt.Value{:}) ;
fclose(fid) ;
  4 commentaires
Rik
Rik le 5 Août 2017
You might need to replace the control characters:
escaped_cellstr=app.DCMtxt.Value;
escaped_cellstr=strrep(escaped_cellstr,'%','%%');
escaped_cellstr=strrep(escaped_cellstr,'/','//');
fid = fopen('output.txt','w');
fprintf(fid, '%s\n',escaped_cellstr) ;
fclose(fid) ;
Walter Roberson
Walter Roberson le 5 Août 2017
No, Rik, that is not needed. That would only be needed if you were using the string content inside the format. For example, the following would be a problem:
fid = fopen('output.txt','w');
for jj = 1 : size( app.DCMtxt.Value, 1 )
fprintf( fid, app.DCMtxt.Value{jj,1} );
fprintf( fid, '\n' );
end
fclose(fid);

Connectez-vous pour commenter.

Plus de réponses (1)

Will Wilson
Will Wilson le 4 Août 2017
If you didn't want to use a for loop directly you could use a newer datatype called a table and one if it's helper functions to get the job done. Here is an example:
% Convert your [m x 1] cell array into a MATLAB table.
data = cell2table(app.DCMtxt.Value);
% (Optionally) name the column in your table.
data.Properties.VariableNames = {'DataSet'};
% Write the table out to a text file.
writetable(data,'OutputData');
This should do the trick. Ultimately it will depend on how much control you need on the text file you write out.

Catégories

En savoir plus sur Text Data Preparation dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by