那他呢
>>> data = struct.pack('2I',12, 30)>>> [hex(ord(c)) for c in data]['0xc', '0x0', '0x0', '0x0', '0x1e', '0x0', '0x0', '0x0']
该表达式
[item for item in sequence]是所谓的
列表理解 。基本上,这是编写简单
for循环并根据结果创建列表的非常紧凑的方式。
的
ord()内置函数采用一个字符串,并把它转换成一个整数其相应的Unipre代码点(在ASCII字符集这是与它们在ASCII表值中的字符)这是。
chr()对于8bit字符串或
unichr()unipre对象,它的对应内容与此相反。
然后,
hex()内建函数将整数简单地转换为十六进制表示形式。
正如@TimPeters指出的那样,在Python 3中,您将需要丢失
ord(),因为在字节对象上进行迭代将(已经)产生整数:
Python 3.4.0a3 (default, Nov 8 2013, 18:33:56)>>> import struct>>> data = struct.pack('2I',12, 30)>>> type(data)<class 'bytes'>>>> type(data[1])<class 'int'>>>>>>> [hex(i) for i in data]['0xc', '0x0', '0x0', '0x0', '0x1e', '0x0', '0x0', '0x0']
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)