如何在Python中将十六进制字符串分割为列表?
如果我有这个字符串:
hexstring = '001122334455'
我该怎么把它分割成一个列表,这样结果就是:
hexlist = ['00', '11', '22', '33', '44', '55']
我想不出一个简单、优雅的Python方法来做到这一点 :/
7 个回答
3
有一种稍微奇怪的方法:
map(''.join,zip(hexstring[::2],hexstring[1::2]))
7
另外:
>>> hexstring = "01234567"
>>> it=iter(hexstring); [a+b for a,b in zip(it, it)]
['01', '23', '45', '67']
如果你在使用 Python 2.x,建议用 itertools.izip
来替代 zip
。
这个方法是 itertools 这个库里的一种特定版本的 grouper
。
一些微型基准测试:
$ python2.6 -m timeit -s 'hexstring = "01234567"*500' '[hexstring[i:i+2] for i in xrange(0,len(hexstring), 2)]' 1000 loops, best of 3: 409 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"*500' '[hexstring[i:i+2] for i in range(0,len(hexstring), 2)]' 1000 loops, best of 3: 438 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"*500' 'it=iter(hexstring); [a+b for a,b in zip(it, it)]' 1000 loops, best of 3: 526 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"*500; from itertools import izip' 'it=iter(hexstring); [a+b for a,b in izip(it, it)]' 1000 loops, best of 3: 406 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"*500; import re; r=re.compile(".{1,2}"); f=r.findall' 'f(hexstring)' 1000 loops, best of 3: 458 usec per loop $ python3.1 -m timeit -s 'hexstring = "01234567"*500' '[hexstring[i:i+2] for i in range(0,len(hexstring), 2)]' 1000 loops, best of 3: 756 usec per loop $ python3.1 -m timeit -s 'hexstring = "01234567"*500' 'it=iter(hexstring); [a+b for a,b in zip(it, it)]' 1000 loops, best of 3: 414 usec per loop $ python3.1 -m timeit -s 'hexstring = "01234567"*500; import re; r=re.compile(".{1,2}"); f=r.findall' 'f(hexstring)' 1000 loops, best of 3: 865 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"' '[hexstring[i:i+2] for i in xrange(0,len(hexstring), 2)]' 1000000 loops, best of 3: 1.52 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"' '[hexstring[i:i+2] for i in range(0,len(hexstring), 2)]' 1000000 loops, best of 3: 1.76 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"' 'it=iter(hexstring); [a+b for a,b in zip(it, it)]' 100000 loops, best of 3: 3.78 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"; from itertools import izip' 'it=iter(hexstring); [a+b for a,b in izip(it, it)]' 100000 loops, best of 3: 2.39 usec per loop $ python2.6 -m timeit -s 'hexstring = "01234567"; import re; r=re.compile(".{1,2}"); f=r.findall' 'f(hexstring)' 1000000 loops, best of 3: 1.45 usec per loop $ python3.1 -m timeit -s 'hexstring = "01234567"' '[hexstring[i:i+2] for i in range(0,len(hexstring), 2)]' 100000 loops, best of 3: 2.46 usec per loop $ python3.1 -m timeit -s 'hexstring = "01234567"' 'it=iter(hexstring); [a+b for a,b in zip(it, it)]' 1000000 loops, best of 3: 1.84 usec per loop $ python3.1 -m timeit -s 'hexstring = "01234567"; import re; r=re.compile(".{1,2}"); f=r.findall' 'f(hexstring)' 100000 loops, best of 3: 2.07 usec per loop
观察:
- 在 Python 2.6 中处理长字符串时,@SilentGhost 和我的方法是最快的。当然,你需要使用懒加载的迭代器,比如
xrange
和izip
。 - 在 Python 2.6 中处理短字符串时,@Nick 的正则表达式是最快的。
- 在 Python 3.1 中,我的方法在两种情况下都是最快的,但我认为这是因为 Python 3.x 的优化程度较低。
- 当然,过早优化是有害的,等等。
15
这段代码的意思是……
首先,它会做一些准备工作,比如设置一些变量或者导入需要用到的库。接着,它会执行一些操作,比如循环、条件判断等,来处理数据或者实现某个功能。最后,它可能会输出结果,或者将处理后的数据保存到文件中。
总之,这段代码的主要目的是为了完成某个特定的任务,帮助我们更方便地处理信息。
>>> [hexstring[i:i+2] for i in range(0,len(hexstring), 2)]
['00', '11', '22', '33', '44', '55']