Преобразуйте целое число в его символьный эквивалент, где 0 => a, 1 => b и т. Д. - PullRequest
160 голосов
/ 30 июня 2010

Я хочу преобразовать целое число в его символьный эквивалент на основе алфавита.Например:

0 => a
1 => b
2 => c
3 => d

и т. Д.Я мог бы создать массив и просто посмотреть его, когда мне это нужно, но мне интересно, есть ли встроенная функция, чтобы сделать это для меня.Все примеры, которые я нашел через Google, работают со значениями ASCII, а не с позицией символа в алфавите.

Ответы [ 12 ]

301 голосов
/ 30 июня 2010

Предполагая, что вам нужны строчные буквы:

var chr = String.fromCharCode(97 + n); // where n is 0, 1, 2 ...

97 - это код ASCII для строчных букв «а». Если вам нужны заглавные буквы, замените 97 на 65 (заглавная 'A'). Обратите внимание, что если n > 25, вы выйдете из диапазона букв.

80 голосов
/ 30 июня 2010

Будет более переносимым в случае расширения до других алфавитов:

char='abcdefghijklmnopqrstuvwxyz'[code]

или, чтобы быть более совместимым (с нашим любимым IE):

char='abcdefghijklmnopqrstuvwxyz'.charAt(code);
26 голосов
/ 14 августа 2015

Если вы не против вернуть многосимвольные строки, вы можете поддерживать произвольные положительные индексы:

function idOf(i) {
    return (i >= 26 ? idOf((i / 26 >> 0) - 1) : '') +  'abcdefghijklmnopqrstuvwxyz'[i % 26 >> 0];
}

idOf(0) // a
idOf(1) // b
idOf(25) // z
idOf(26) // aa
idOf(27) // ab
idOf(701) // zz
idOf(702) // aaa
idOf(703) // aab

(Недостаточно проверен на точность ошибок:)

17 голосов
/ 20 мая 2016

Простой ответ будет (26 символов):

String.fromCharCode(97+n);

Если пространство драгоценное, вы можете сделать следующее (20 символов):

(10+n).toString(36);

Подумайте, что вы могли бысо всеми этими дополнительными байтами!

Как это работает, вы конвертируете число в основание 36, поэтому у вас есть следующие символы:

0123456789abcdefghijklmnopqrstuvwxyz
^         ^
n        n+10

Смещением на 10 символов начинаются с a вместо 0.

Не совсем уверен в том, насколько быстрым будет выполнение двух разных примеров на стороне клиента.

6 голосов
/ 30 июня 2010

Javascript String.fromCharCode (code1, code2, ..., codeN) принимает бесконечное количество аргументов и возвращает строку букв, соответствующие значения ASCII которых code1, code2, ... codeN Поскольку 97 является «a» в ASCII, мы можем откорректировать вашу индексацию, добавив 97 к вашему индексу.

function indexToChar(i) {
  return String.fromCharCode(i+97); //97 in ASCII is 'a', so i=0 returns 'a', 
                                    // i=1 returns 'b', etc
}
3 голосов
/ 30 июня 2010

Используйте String.fromCharCode.Это возвращает строку из значения Unicode, которое соответствует первым 128 символам ASCII.

var a = String.fromCharCode(97);
2 голосов
/ 30 июня 2010

Вот, пожалуйста: (a-zA-Z)

function codeToChar( number ) {
  if ( number >= 0 && number <= 25 ) // a-z
    number = number + 97;
  else if ( number >= 26 && number <= 51 ) // A-Z
    number = number + (65-26);
  else
    return false; // range error
  return String.fromCharCode( number );
}

ввод: 0-51, или он вернет false (ошибка диапазона);

OR

var codeToChar = function() {
  var abc = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ".split("");
  return function( code ) {
    return abc[code];
  };
})();

возвращает неопределенное значение в случае ошибки диапазона. ПРИМЕЧАНИЕ: массив будет создан только один раз, и из-за закрытия он будет доступен для новой функции codeToChar. Я думаю, что это даже быстрее, чем первый метод (это просто поиск в принципе).

1 голос
/ 26 сентября 2018

Мне не нравятся все решения, использующие магические числа, такие как 97 или 36.

const A = 'A'.charCodeAt(0);

let numberToCharacter = number => String.fromCharCode(A + number);

let characterToNumber = character => character.charCodeAt(0) - A;

, здесь предполагаются заглавные буквы и начинается буква A с 0.

1 голос
/ 11 января 2018

Единственная проблема с отличным решением @ mikemaccana состоит в том, что в нем используется двоичный оператор >>, который является дорогостоящим и повышает производительность. Я предлагаю эту модификацию его великой работы как небольшое улучшение, которое, возможно, ваши коллеги могут читать легче.

const getColumnName = (i) => {
     const previousLetters = (i >= 26 ? getColumnName(Math.floor(i / 26) -1 ) : '');
     const lastLetter = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'[i % 26]; 
     return previousLetters + lastLetter;
}

или как однострочный

const getColumnName = i => (i >= 26 ? getColumnName(Math.floor(i / 26) -1 ) : '') + 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'[i % 26];

Пример:

getColumnName(0); // "A"
getColumnName(1); // "B"
getColumnName(25); // "Z"
getColumnName(26); // "AA"
getColumnName(27); // "AB"
getColumnName(80085) // "DNLF"
0 голосов
/ 13 июля 2017

Генерирует случайное число и символ для проверки телефона или чего-то еще.

function randomIntFromInterval(min,max)
{
    return Math.floor(Math.random()*(max-min+1)+min);
}




function generateRandomVerification(length){
let char;
let sum ="";
  for(let i=0;i < length;i++){
    if(Math.round(Math.random())){
      random = randomIntFromInterval(65,90);
      char = String.fromCharCode(random);//65-90
      sum = sum + char;
      console.log("CHAR: ", char);
    }else{
      random = randomIntFromInterval(48,57);
      char = String.fromCharCode(random);//48-57
      sum = sum + char;
      console.log("CHAR: ", char);
    }
  }
  alert(sum);
}

generateRandomVerification(5);

Вот ссылка

...