How can I properly format small numbers using num2str?

14 views (last 30 days)
I was assigned to work on the aesthetics of a table that shows collected data as string.
I want to show the numbers with 4 digits percision, but whenever the number is bigger the 10e-5, the output will include all the zeros, and only the four digits, e.g:
x=0.000123456;
y=0.0000123456;
solx=num2str(x,'%.4G');
soly=num2str(y,'%.4G');
solx
solx = '0.0001235'
soly
soly = '1.235E-05'
Is there any way that I can get solx to be formatted like soly?

Accepted Answer

David Hill
David Hill on 17 Aug 2021
soly=num2str(y,'%.3E')
solx=num2str(x,'%.3E')
  3 Comments
Simon Chan
Simon Chan on 18 Aug 2021
Write a function which can change the display format based on the magnitude of the data.
Walter Roberson
Walter Roberson on 18 Aug 2021
Simon is correct.
The only conditional formatting that MATLAB supplies in any released version, is what is done automatically by "format short" or "format long", or done by a %g format for sprintf() or fprintf() or compose() -- none of which permit tuning the boundaries of when values are to be shown in which varient.

Sign in to comment.

More Answers (0)

Products


Release

R2020b

Community Treasure Hunt

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

Start Hunting!