Turning numbers into letters based on alphabetical order

17 visualizaciones (últimos 30 días)
Hi all, I am trying to export multiple matrix variable that change in size to an excel file. To get their spacing right I need to give a cell name (eg. 'B3') where I want the variable to be placed. However, I want to be able to space my matrices based on their number of columns, which mean taking a length() command and turning it into a letter. Is there any built in way in matlab to do this. an example of what I'm looking for is below.
function(7)
ans G (because it is the 7th letter in the alphabet)
There may be an easier way of doing this with xlswrite but I dont know it. Thanks
Brendan
  1 comentario
Christian Lopez Garcia
Christian Lopez Garcia el 25 de Jul. de 2019
num=26;
position = alphabet(num)
function position=alphabet(num)
mult=floor(num/26);
diff=num-26*mult;
symbols = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
range=26.*[1:26];
if num>26
for i=1:length(range)
if (num >= range(i) && num <= range(i+1))
start=string(symbols(i))
end
end
if diff > 0
extension=string(symbols(diff))
position=char(start+extension+'1')
else diff=0
extension=string(symbols(26))
position=char(start+extension+'1')
end
else
position=string(symbols(num));
position=char(position + '1');
end
end

Iniciar sesión para comentar.

Respuesta aceptada

Titus Edelhofer
Titus Edelhofer el 15 de Jun. de 2012
Hi Brendan,
something like this:
n = 7;
char('A'+(n-1))
What I forgot: you might also think about taking
n1 = rem(n, 26);
n2 = floor(n/26);
in order to have e.g. "AE" for n=31 ...
Titus
  4 comentarios
Guillaume
Guillaume el 15 de Abr. de 2015
Julian, your answer is probably the most comprehensive so you may consider reposting it as an actual answer rather than a comment, so you can at least get some votes for it, even if it can't be the accepted answer anyway.
That is, if you want some reputation points.
Titus Edelhofer
Titus Edelhofer el 15 de Abr. de 2015
Or you might submit this to the File Exchange, if nothing similar is there already ...

Iniciar sesión para comentar.

Más respuestas (1)

the cyclist
the cyclist el 15 de Jun. de 2012
There's not an explicit builtin for this, but it is easy to write:
function c = letterRankToLetter(n)
c = char('A'+n-1);
end
This will only work for n in the range 1-26, so you might want to put some error-checking in there.

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by