3

わかりましたので、基数 32 の 16 進数 (別名 Triacontakaidecimal) から整数への変換は非常に簡単です。たとえば、次のようになります。

>>>int("v", 32)
31

逆にどうやってやるの?方法がない場合は、辞書を作成することを考えていました。

編集:

私は実際に辞書でこれを機能させました。私のこのメソッドのアイデアは、ベース32の16進文字を取得し、LSBが1に設定されていない場合にそれをインクリメントすることでした

>>> def incHex(hexChar):
...     intRep = int(hexChar, 32)
...     binRep = bin(intRep)
...     if(binRep[-1:]!='1'):
...         intRep += 1
...     convDict = {0:0,1:1,2:2,3:3,4:4,5:5,6:6,7:7,8:8,9:9,10:'A',11:'B',12:'C',
...                 13:'D',14:'E',15:'F',16:'G',17:'H',18:'I',19:'J',20:'K',21:'L',
...                 22:'M',23:'N',24:'O',25:'P',26:'Q',27:'R',28:'S',29:'T',30:'U',
...                 31:'V'}
...     return convDict[intRep]
...
>>> incHex('l')
'L'
>>> incHex('m')
'N'
>>>
4

4 に答える 4

3

辞書は、おそらくやりたいことに対して少しやり過ぎです。タプルを使用しない理由:

convTable = ('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V')

これにより、メモリを節約しながらルックアップが高速化されます。

0 ~ 31 の範囲の整数を検索するだけの場合は、次のようにします。

getHex32Rep(val):
    return convTable[val]

また、おそらくやりたいこと:

if(binRep[-1]!='1'):

それ以外の

if(binRep[-1:]!='1'):
于 2011-07-14T11:53:02.900 に答える
2

convDict を作成する別の方法

>>> import string
>>> convDict = {c:int(c,32) for c in (string.digits+string.ascii_lowercase)[:32]}
>>> convDict
{'1': 1, '0': 0, '3': 3, '2': 2, '5': 5, '4': 4, '7': 7, '6': 6, '9': 9, '8': 8, 'a': 10, 'c': 12, 'b': 11, 'e': 14, 'd': 13, 'g': 16, 'f': 15, 'i': 18, 'h': 17, 'k': 20, 'j': 19, 'm': 22, 'l': 21, 'o': 24, 'n': 23, 'q': 26, 'p': 25, 's': 28, 'r': 27, 'u': 30, 't': 29, 'v': 31}
于 2011-07-14T11:58:13.313 に答える
1

これを提供しているように見えるnumconvパッケージを見つけましたか?

于 2011-07-14T12:43:52.657 に答える