How do I add commas to numbers using fprintf?
Mostra commenti meno recenti
Hello,
How do I add commas to numbers using fprintf? My customer wants me to write out tables and have commas in the numbers to better read it. For instance, 123456789.0 would be written out as 123,456,789.0. Thanks.
Best regards,
Bill Rooker
Risposta accettata
Più risposte (4)
Ted Shultz
il 13 Giu 2018
function numOut = addComma(numIn)
jf=java.text.DecimalFormat; % comma for thousands, three decimal places
numOut= char(jf.format(numIn)); % omit "char" if you want a string out
end
Hope that helps! --ted
5 Commenti
Roscoe Cook
il 15 Mag 2019
Worked great for me! Perhaps this should be the accepted answer. Thanks!
Stargaet
il 19 Lug 2019
very good! thanks!
Kouichi C. Nakamura
il 15 Feb 2020
Thanks! Extended it to 2d matrix.
function B = AddCommaArr(A)
B = strings(size(A));
for i = 1:size(A,1)
for j = 1:size(A,2)
B(i,j) = addComma(A(i,j));
end
end
function numOut = addComma(numIn)
jf=java.text.DecimalFormat; % comma for thousands, three decimal places
numOut= char(jf.format(numIn)); % omit "char" if you want a string out
end
end
Daven Gooden
il 10 Nov 2020
@Ted Shultz: Spot on! Very clean and easy to understand/use! Thank you very mutch!
Edwin Cortez
il 2 Feb 2022
Modificato: Edwin Cortez
il 2 Feb 2022
Great ! Thanks
Jim Svensson
il 15 Feb 2021
9 voti
I feel that in 2021 this functionality should be supported by sprintf/fprintf.
3 Commenti
Jim Svensson
il 15 Set 2023
Spostato: Dyuman Joshi
il 15 Set 2023
I feel that in 2023 this functionality should be supported by sprintf/fprintf.
Dyuman Joshi
il 15 Set 2023
@Jim Svensson If you want to have a functionality implemented in MATLAB, you can raise a feature request for it.
I believe you will need a strong justification to convince TMW as to why they should implement it.
Image Analyst
il 16 Set 2023
It would certainly be a convenience if they had a letter to do that conversion, like p or whatever (some unused letter), like
x = 12345678.912345
fprintf('Number = %p.\n', x);
'12,345,678.912'
See my attached utility function that inserts commas to make a string out of a number. Then in your fprintf you print the string with %s instead of %d or %f. For example:
number = 1234567;
fprintf('The number is %s.\n', CommaFormat(number));
Using pattern
vec = 123456789;
txt = string(vec);
pat1 = lookBehindBoundary(digitsPattern); % (?<=\d)
pat2 = asManyOfPattern(digitsPattern(3),1); % (\d{3})+
pat3 = lookAheadBoundary(pat2+lineBoundary("end")); % (?=(\d{3})+$)
pat4 = pat1+pat3; % (?<=\d)(?=(\d{3})+$)
replace(txt,pat4,",")
1 Commento
vec = 1234.56789
txt = string(vec);
pat1 = lookBehindBoundary(digitsPattern); % (?<=\d)
pat2 = asManyOfPattern(digitsPattern(3),1); % (\d{3})+
pat3 = lookAheadBoundary(pat2+lineBoundary("end")); % (?=(\d{3})+$)
pat4 = pat1+pat3; % (?<=\d)(?=(\d{3})+$)
replace(txt,pat4,",")
Categorie
Scopri di più su Loops and Conditional Statements in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!