Turning numbers into letters based on alphabetical order
22 次查看(过去 30 天)
显示 更早的评论
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 个评论
Christian Lopez Garcia
2019-7-25
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
采纳的回答
Titus Edelhofer
2012-6-15
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 个评论
Guillaume
2015-4-15
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
2015-4-15
Or you might submit this to the File Exchange, if nothing similar is there already ...
更多回答(1 个)
the cyclist
2012-6-15
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.
0 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Loops and Conditional Statements 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!