Я не использовал struct
много, но между вашим кодом и документами я получил его для работы с буфером, в котором хранится массив целых чисел.
Создание байтового массива / строки из numpy
array.
In [81]: arr = np.arange(1000)
In [82]: barr = arr.tobytes()
In [83]: type(barr)
Out[83]: bytes
In [84]: len(barr)
Out[84]: 8000
Обратное значение tobytes
:
In [85]: x = np.frombuffer(barr, dtype=int)
In [86]: x[:10]
Out[86]: array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
In [87]: np.allclose(x,arr)
Out[87]: True
ndarray
также работает, хотя прямое использование этого конструктора обычно не рекомендуется:
In [88]: x = np.ndarray(buffer=barr, dtype=int, shape=(1000,))
In [89]: np.allclose(x,arr)
Out[89]: True
Чтобы использовать struct
Мне нужно создать формат, который включает в себя длину, «1000 long»:
In [90]: tup = struct.unpack('1000l', barr)
In [91]: len(tup)
Out[91]: 1000
In [92]: tup[:10]
Out[92]: (0, 1, 2, 3, 4, 5, 6, 7, 8, 9)
In [93]: np.allclose(np.array(tup),arr)
Out[93]: True
Итак, теперь, когда мы установили эквивалентные методы чтения буфера, сделайте нескольковремя:
In [94]: timeit x = np.frombuffer(barr, dtype=int)
617 ns ± 0.806 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
In [95]: timeit x = np.ndarray(buffer=barr, dtype=int, shape=(1000,))
1.11 µs ± 1.76 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
In [96]: timeit tup = struct.unpack('1000l', barr)
19 µs ± 38.4 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
In [97]: timeit tup = np.array(struct.unpack('1000l', barr))
87.5 µs ± 25.1 ns per loop (mean ± std. dev. of 7 runs, 10000 loops each)
frombuffer
выглядит довольно хорошо.
Ваша петля struct.unpack
смущает меня.Я не думаю, что он делает то же самое, что и frombuffer
.Но, как было сказано в начале, я не использовал struct
.