transfer numerical data end with 'M' and 'B'

조회 수: 1 (최근 30일)
Yu Li
Yu Li 2024년 3월 7일
편집: Stephen23 2024년 3월 7일
Hi:
I have a numerical data that is for example, 1234567, I can translate to "%f" and "%e" format using Matlab, but I would like to transfer the data to something like this: 1.23M, where "M" represent "million", simliar if the data is even larger, over billion, I can transfer it as "1.2b".
is it possible to do this is Matlab?
Thanks!
Yu
  댓글 수: 4
Dyuman Joshi
Dyuman Joshi 2024년 3월 7일
편집: Dyuman Joshi 2024년 3월 7일
No, there is no official MATLAB command that does that. You will have to write the code for it.
You can utilize the hint that I provided above.
P.S - Isn't the symbol for billion supposed to be B and not b?
Stephen23
Stephen23 2024년 3월 7일
편집: Stephen23 2024년 3월 7일
As an alternative, you could download and try using my function NUM2WORDS():
It covers the entire DOUBLE range, has many options, and has been extensively tested:
num2words(1234567,'type','highest','sigfig',3)
ans = 'one point two three million'
Note that if you only use the first letter you will have a problem when you reach Quadrillion and Quintillion.
Or you could download my function NUM2SIP():
It provides all of the SI prefixes, and has also been extensively tested:
num2sip(1234567,3)
ans = '1.23 M'

댓글을 달려면 로그인하십시오.

답변 (1개)

Chunru
Chunru 2024년 3월 7일
You can define your own function. Here is an example:
sprintfkmb(12345678)
ans = "12.345678M"
sprintfkmb(-12345678)
ans = "-12.345678M"
sprintfkmb(-1238)
ans = "-1.238000k"
sprintfkmb(-1234567890123)
ans = "-1234.567890b"
function s = sprintfkmb(a)
str = ["", "k", "M", "b"];
e = floor(log10(abs(a)));
e3 = floor(e/3);
e3 = min(e3, 3);
s = sprintf("%.6f%s", a/(10^(e3*3)), str(e3+1) );
end

카테고리

Help CenterFile Exchange에서 Characters and Strings에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by