使用
struct模块;
您需要以该库记录的字符串格式定义类型:
struct.unpack('=HHf255s', bytes)
上面的示例期望本机字节顺序,两个无符号短裤,一个浮点数和一个255个字符的字符串。
要遍历一个已经完全读取的
bytes字符串,我要使用
itertools;
我在这里有一个方便的石斑鱼食谱:
from itertools import izip_longest, imapfrom struct import unpack, calcsizefmt_s = '=5i'fmt_spec = '=256i'size_s = calcsize(fmt_s)size = size_s + calcsize(fmt_spec)def chunked(iterable, n, fillvalue=''): args = [iter(iterable)] * n return imap(''.join, izip_longest(*args, fillvalue=fillvalue))data = [unpack(fmt_s, section[:size_s]) + (unpack(fmt_spec, section[size_s:]),) for section in chunked(bytes, size)]
这将产生元组而不是列表,但是如果必须进行调整,就很容易进行调整:
data = [list(unpack(fmt_s, section[:size_s])) + [list(unpack(fmt_spec, section[size_s:]))] for section in chunked(bytes, size)]
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)