首页 > 解决方案 > unpack 需要一个长度为 32 的字节对象

问题描述

我需要打包数据并导出到 csv 文件以及读取该 csv 文件并解码数据。

这是我打包数据的代码

from struct import *

raw_data = [[76.94,76.944,76.945],[76.97,76.979,76.980],[77.025,77.025,77.025]]
for data in raw_data:
    binary_format = pack('fff',raw_data[0][0],raw_data[0][1],raw_data[0][2])
    print(binary_format)
    list_data = [binary_format]

    with open('samples.csv','a') as csvFile:
        writer=csv.writer(csvFile,delimiter=',',quoting=csv.QUOTE_MINIMAL)
        writer.writerows(list_data)                                                  
        csvFile.close()

这是用于解码数据。

import csv
from struct import *

formater = 'fff'
with open('samples.csv', 'rb') as csvFile:
    reader = csv.reader(csvFile)
    for row in reader:
        print(unpack(formater,row[0].encode('UTF-8')))
csvFile.close()

以下错误是

struct.error: unpack 需要一个长度为 32 的字节对象

像这样的异常输出

76.94,76.944,76.945
76.97,76.979,76.980
77.025,77.025,77.025

标签: python-3.xcsv

解决方案


这是打包/解包如何工作的一个小例子。

x = pack("ddd", 22, 33, 44)

x在这种情况下是b'\x00\x00\x00\x00\x00\x006@\x00\x00\x00\x00\x00\x80@@\x00\x00\x00\x00\x00\x00F@'

unpack(x)产量(22.0, 33.0, 44.0)

您从 CSV 检索的数据是十六进制的吗?


推荐阅读