繁体   English   中英

如何将任意基数的字符串版本转换为整数?

[英]How do I convert a string version of a number in an arbitrary base to an integer?

如何将字符串转换为整数?

例如:

  • “ 5328764”,以int为基础的10
  • “ AB3F3A”,以int为基数16

任何代码都会有所帮助

假设任意基数(不是16、10、8、2):

在C(C ++)中,使用strtol

return strtol("AB3F3A", NULL, 16);

在Javascript中,使用parseInt

return parseInt("AB3F3A", 16);

在Python中,使用int(string, base)

return int("AB3F3A", 16)

在Java中,使用Integer.parseInt (感谢Michael。)

return Integer.parseInt("AB3F3A", 16);

在PHP中,使用base_convert

return intval(base_convert('AB3F3A', 16, 10));

在Ruby中,使用to_i

"AB3F3A".to_i(16)

在C#中,自己编写一个。

9999实际上是9000 + 900 + 90 + 9因此,从字符串的右侧开始,然后一次选取一个数字。 每个字符号都有一个ASCII码,可以将其转换为数字并乘以适当的数量。

在C#中,我认为它是:Convert.ToInt64(value,base)并且基数必须为2、8、10或16

Java中的两个函数,双向:“ code”参数代表数值系统:“ 01”表示基数2,“ 0123456789”表示基数10,“ 0123456789abcdef”表示十六进制,依此类推...

public String convert(long num, String code) {
    final int base = code.length();
    String text = "";
    while (num > 0) {
        text = code.charAt((int) (num%base)) + text;
        num /= base;
    }
    return text;
}

public long toLong(String text, String code) {
    final long base = code.length();
    long num = 0;
    long pow = 1;
    int len = text.length();
    for(int i = 0; i < len; i++) {
        num += code.indexOf(text.charAt(len - i - 1)) * pow;
        pow *= base;
    }
    return num;
}

println(convert(9223372036854775807L,"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"));
println(convert(9223372036854775807L,"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@=-+*/^%$#&()!?.,:;[]"));
println(toLong("Ns8T$87=uh","0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@=-+*/^%$#&()!?.,:;[]"));```

在您的示例中:

toLong("5328764", "0123456789") = 5328764
toLong("AB3F3A", "0123456789ABCDEF") = 11222842

暂无
暂无

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

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