How do I add commas to numbers using fprintf?
Show older comments
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
Accepted Answer
More Answers (4)
Ted Shultz
on 13 Jun 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 Comments
Roscoe Cook
on 15 May 2019
Worked great for me! Perhaps this should be the accepted answer. Thanks!
Stargaet
on 19 Jul 2019
very good! thanks!
Kouichi C. Nakamura
on 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
on 10 Nov 2020
@Ted Shultz: Spot on! Very clean and easy to understand/use! Thank you very mutch!
Edwin Cortez
on 2 Feb 2022
Edited: Edwin Cortez
on 2 Feb 2022
Great ! Thanks
Jim Svensson
on 15 Feb 2021
9 votes
I feel that in 2021 this functionality should be supported by sprintf/fprintf.
3 Comments
Jim Svensson
on 15 Sep 2023
Moved: Dyuman Joshi
on 15 Sep 2023
I feel that in 2023 this functionality should be supported by sprintf/fprintf.
Dyuman Joshi
on 15 Sep 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
on 16 Sep 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 Comment
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,",")
Categories
Find more on Characters and Strings in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!