繁体   English   中英

在 JavaScript 中将字母转换为数字

[英]Convert letter to number in JavaScript

我想知道如何将输入的每个字母字符转换为数字。

例如 a=1, b=2 ,c=3 直到 z=26

在 CI 中,通过接受字符输入并将其显示为整数,设法做类似的事情。 但我不确定我将如何在 JavaScript 中做到这一点。

如果我猜对了,其他答案就太复杂了:

parseInt('a', 36) - 9; // 1
parseInt('z', 36) - 9; // 26
parseInt('A', 36) - 9; // 1
parseInt('Z', 36) - 9; // 26

现在,回答您在评论中提出的问题:

 function sumChars(s) { var i, n = s.length, acc = 0; for (i = 0; i < n; i++) { acc += parseInt(s[i], 36) - 9; } return acc; } console.log(sumChars("az"))

但是,与位置表示法相比,这种整数表示法更占用空间。 比较两种符号中的“baz”:

sumChars("baz") // 29
parseInt("baz", 36) // 14651

在此处输入图片说明

正如你所看到的,字母的数量是一样的,但以 36 为底的整数要大得多。 此外,将基数为 10 的整数转换为基数 36 在 JavaScript 中是微不足道的:

(14651).toString(36) // "baz"

最后,当您想要存储值时要小心。 虽然听起来违反直觉,但基数 2 比基数 36 更紧凑。 事实上,一个字母在内存中至少占据 8 位:

(35).toString(2).length // 6 bits long
(35).toString(36).length * 8 // 8 bits long

因此,我建议使用“真实”整数进行存储,无论如何很容易将其恢复为基数 36。

var alphabet = ["a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"];
var letter = "h";
var letterPosition = alphabet.indexOf(letter)+1;

编辑:

可以计算字符串中的字母,aa=2,ab=3 等。

function str_split(string, split_length) {
  //  discuss at: http://phpjs.org/functions/str_split/
  // original by: Martijn Wieringa
  // improved by: Brett Zamir (http://brett-zamir.me)
  // bugfixed by: Onno Marsman
  //  revised by: Theriault
  //  revised by: Rafał Kukawski (http://blog.kukawski.pl/)
  //    input by: Bjorn Roesbeke (http://www.bjornroesbeke.be/)
  //   example 1: str_split('Hello Friend', 3);
  //   returns 1: ['Hel', 'lo ', 'Fri', 'end']

  if (split_length == null) {
    split_length = 1;
  }
  if (string == null || split_length < 1) {
    return false;
  }
  string += '';
  var chunks = [],
    pos = 0,
    len = string.length;
  while (pos < len) {
    chunks.push(string.slice(pos, pos += split_length));
  }

  return chunks;
}


function count(string){
    var alphabet = ["a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"];

    var splitted_string = str_split(string);

    var count = 0;
    for (i = 0; i < splitted_string.length; i++) { 
        var letterPosition = alphabet.indexOf(splitted_string[i])+1;
        count = count + letterPosition;
    }
    return count;
}

console.log(count("az")); // returns 27 in the console

在 JavaScript 中,字符不是单字节数据类型,所以如果你想模仿 C 的工作方式,你需要自己创建一个映射。

例如使用一个简单的对象作为地图:

var characters: {
    'a': 1,
    'b': 2,
    ...
}

这样var number = charachters['a']; 将 number 设置为1 其他人提供了短路方法,这很可能是更可行的,这个主要是为了易于理解。

你可以这样做

function convertToNumbers(str){
   var arr = "abcdefghijklmnopqrstuvwxyz".split("");
   return str.replace(/[a-z]/ig, function(m){ return arr.indexOf(m.toLowerCase()) + 1 });
}

您所做的是创建一个字母数组,然后使用String.replace函数中的回调并返回字母+1的相应索引,因为索引从0开始

这将工作

"abcdefghijklmnopqrstuvwxyz".split("").forEach(function (a,b,c){ console.log(a.toLowerCase().charCodeAt(0)-96)});


"iloveyou".split("").forEach(function (a,b,c){ console.log(a.toLowerCase().charCodeAt(0)-96)});

9
12
15
22
5
25
15
21

您可以制作一个映射值的对象-

function letterValue(str){
    var anum={
        a: 1, b: 2, c: 3, d: 4, e: 5, f: 6, g: 7, h: 8, i: 9, j: 10, k: 11, 
        l: 12, m: 13, n: 14,o: 15, p: 16, q: 17, r: 18, s: 19, t: 20, 
        u: 21, v: 22, w: 23, x: 24, y: 25, z: 26
    }
    if(str.length== 1) return anum[str] || ' ';
    return str.split('').map(letterValue);
}

letterValue('zoo')返回: (Array) [26,15,15] ;

letterValue('z')返回:(数字)26

您可以只获得 ascii 值和大写字母的负 64。

var letterPlacement = "A".charCodeAt(0) - 64;

或负 96 表示小写。

var letterPlacement = "a".charCodeAt(0) - 96;

或者作为一个漂亮而整洁的单行函数,不关心案例:

function alphabetifier(letter) {
    return letter.charCodeAt(0) - (letter === letter.toLowerCase() ? 96 : 64);
}      

 function convertAlpha(ch){ //ASCII code of a is 97 so subtracting 96 would give 1 and so on return ch.charCodeAt(0)-96; } console.log(convertAlpha("b")); // returns 2

可以对带有 if 子句的大写字母进行类似的操作。 在大写字母的情况下,我们将减去 64,因为 'A' 的 ASCII 值是 65,所以 65-64 = 1,对于其他字母,依此类推。

你可以试试这个简单的功能。

#Soln 1。

function createIndecesFromChar() {
  let hash = {};
  for(let n = 1; n <= 26; n++) {
     hash[String.fromCharCode(96+n)] = n;     // in case of lowercase letters;
  }

  return hash;
}

console.log(createIndecesFromChar());

// output 
// { a: 1, b: 2, c: 3, d: 4, e: 5, f: 6, g: 7, h: 8, i: 9, j: 10, k: 11, l: 12, m: 13, n: 14, o: 15, p: 16, q: 17, r: 18, s: 19, t: 20, u: 21, v: 22, w: 23, x: 24, y: 25, z: 26 }

#Soln 2.另一种功能直接的方法。

const indexedMap = Object.fromEntries(Array.from({ length: 26 }, (_, c) => [String.fromCharCode(97+c), c+1]));

console.log(createIndecesFromChar());

// output - same result as above.
// { a: 1, b: 2, c: 3, d: 4, e: 5, f: 6, g: 7, h: 8, i: 9, j: 10, k: 11, l: 12, m: 13, n: 14, o: 15, p: 16, q: 17, r: 18, s: 19, t: 20, u: 21, v: 22, w: 23, x: 24, y: 25, z: 26 }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM