在给定字符串的python中进行基本转换

时间:2015-11-18 23:45:17

标签: php python python-3.x base

在PHP中,给定一个字符串值(由chars 分隔的整数),我们可以计算它的整数表示:

$hashable = "123A123"; // notice "A" delim
$hash_int = base_convert($hashable, 11, 10);
echo $hash_int;

输出

2151042

这很有用,因为结果对于大范围的字符串(当然是短字符串)是唯一的。我在我的应用程序中使用它来生成ID。

我们如何在python中进行相同的转换?是否可以在PHP和python中为相同的字符串生成相等的整数?

也许首先我们需要使用hashable string hash int ,然后转换整数的基数,但我们究竟是如何做到的呢?

1 个答案:

答案 0 :(得分:3)

以前建议的方法对于二进制和许多其他转换都会失败,这将从2到36的任何基数,并根据php implementation为无效字符串返回0,php实现不会忽略输出中的字母除非您为基数提供无效输入,然后它尝试仅查找数字并进行转换,因此您也无法返回int,并且将在输出中获取字母:

def to_base(n, bse):
    digs = "0123456789abcdefghijklmnopqrstuvwxyz"
    tmp = []
    while n:
        n, i = divmod(n, bse)
        tmp.append(digs[i])
    return "".join(tmp[::-1])



def chng_frm_base(s, frm_bse, to_bse):
    if to_bse < 2 or to_bse > 36 or frm_bse < 2 or frm_bse > 36:
        raise ValueError("bases must be between 2-36")
    try:
        return to_base(int(s, frm_bse), to_bse)
    except ValueError:
        try:
            n = int("".join([ch for ch in s if ch.isdigit()]),frm_bse)
            return to_base(n, to_bse)
        except ValueError:
            return 0

输出:

In [13]: chng_frm_base("123A123", 11, 10)
Out[13]: '2151042'

In [14]: chng_frm_base("123A123", 11, 8)
Out[14]: '10151202'

In [15]: chng_frm_base("123A123", 11, 2)
Out[15]: '1000001101001010000010'

In [16]: chng_frm_base("123A123", 11, 35)
Out[16]: '1f5xc'

In [17]: chng_frm_base("123A123", 11, 1)
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-17-9776e0abca26> in <module>()
----> 1 chng_frm_base("123A123", 11, 1)

<ipython-input-2-9c00d800545d> in chng_frm_base(s, frm_bse, to_bse)
     10 def chng_frm_base(s, frm_bse, to_bse):
     11     if to_bse < 2 or to_bse > 36 or frm_bse < 2 or frm_bse > 36:
---> 12         raise ValueError("bases must be between 2-36")
     13     try:
     14         return (to_base(int(s, frm_bse), to_bse))

ValueError: bases must be between 2-36

In [18]: chng_frm_base("hello world!", 10, 2)
Out[18]: 0

如果你使用php运行相同的例子,那么为所有人输出相同的值。