How to create tab-separated .txt using num2str
13 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
I initially converted some .mat files to tab-separated .txt using dlmwrite, but for some reason the values were not recognized on other platforms, and shows "NaN or non numerical error" instead. I was thinking that num2str could possibly bypass this issue. Here is what I have, but where do I add the tab-separated component?
% Length
load('Lengths.mat')
Len = num2str(DistMatrix)
diary('Lengths.txt')
disp(Len)
diary off
% Weights
load('Weights.mat')
Wei = num2str(CatMatrix)
diary('Weights.txt')
disp(Wei)
diary off
2 commentaires
Adam Danz
le 15 Mai 2019
What is "DistMatrix" ? A matrix? A column vector? A row vector? A numeric scalar? Same with CatMatrix?
Why not use a function that is designed to write to text rather than using diary?
Réponse acceptée
Adam Danz
le 15 Mai 2019
Modifié(e) : Adam Danz
le 16 Mai 2019
DistMatrix = magic(16); % fake matrix 16x16
fn = 'Lengths.txt'; % file name
writematrix(DistMatrix,fn,'Delimiter','\t') % tab delimiter

Prior to r2019a, you can use this low level function but ~17 decimal places will be recorded.
DistMatrix = magic(16); % fake matrix 16x16
fn = 'Lengths.txt'; % file name
save(fn, 'DistMatrix', '-ascii', '-double', '-tabs') % Save matrix to file with tab delimiter
Or you can use dlmread()
DistMatrix = magic(16); % fake matrix 16x16
fn = 'Lengths.txt'; % file name
dlmwrite(fn,DistMatrix,'delimiter','\t')
Or you can use diary() but I don't recommend this. I'm only including it because it's used in the question.
DistMatrix = magic(16); % fake matrix 16x16
fn = 'Lengths.txt'; % file name
diary on
disp(DistMatrix) %display matrix in command window
diary(fn)
diary off
winopen(fn)
2 commentaires
Adam Danz
le 16 Mai 2019
I didn't understand your question. Which method are you applying?
Also, I updated my answer to include two more options for matlab releases prior to r2019a.
Plus de réponses (0)
Voir également
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!