How can I transform a number to string with space using num2str?

54 visualizzazioni (ultimi 30 giorni)
What is the result of "num2str(1,'%2d')"? I think it should be " 1", but the results is "1". I mean there is no space before "1". Actually, the result of "num2str(1,'%02d')" is "01", and the result of "num2str(1,'%-2d')" is "1". And, the result of "sprintf('%2d',1)" is " 1".
How can I transform a number to string with space using num2str?

Risposta accettata

Simon
Simon il 9 Dic 2013
Hi!
Maybe this way?
num = [1000; 1001];
% numeric part
numpart = arrayfun(@(x) sprintf('%2d', mod(x,100)), num, 'UniformOutput', false);
% letter part
letterpart = char(mod(num,26*100)./100+65);
% concat everything
retsult = strcat(letterpart, numpart)

Più risposte (2)

Walter Roberson
Walter Roberson il 5 Dic 2013
Use sprintf instead of nu2str()
sprintf('%2d', 1)
  3 Commenti
Simon
Simon il 5 Dic 2013
Hi!
Please compare
sprintf('%2d\n',[1;11])
and
sprintf('%d\n',[1;11])
Walter Roberson
Walter Roberson il 9 Dic 2013
numt = num(:).'; %make sure it is row vector
rem100 = mod(numt, 100);
lead2600 = mod((numt - rem100) ./ 100, 26) + 65;
longstr = sprintf('%c%2d\n', [lead2600; rem100]);
strs = regexp(longstr, '\n', 'split');

Accedi per commentare.


Jung-Woo
Jung-Woo il 9 Dic 2013
Let me ask another way. Actually, I am trying to convert some numbers to alphabatical ID including alphabet and 2 digit numbers.
For example,
num = [1000; 1011];
cellstr([char(mod(num,26*100)./100+65),num2str(mod(num,100),'%2d')])
ans =
'K 0'
'K11'
That is what I want to have. But, if num = [1000; 1001], the 2-digit numbers become just 1-digit numbers like:
num = [1000; 1001];
cellstr([char(mod(num,26*100)./100+65),num2str(mod(num,100),'%2d')])
ans =
'K0'
'K1'
Here, my question is how I can fix the number of digit to 2. My expectation is:
ans =
'K 0'
'K 1'
  1 Commento
Walter Roberson
Walter Roberson il 9 Dic 2013
You cannot use num2str() for this purpose. In situations in which every entry ends up with a leading blank, num2str() will strip off the leading blank.

Accedi per commentare.

Categorie

Scopri di più su Data Type Conversion in Help Center e File Exchange

Tag

Community Treasure Hunt

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

Start Hunting!

Translated by