Есть ли способ указать Pandas использовать определенный c протокол рассола (например, 4) при записи файла HDF5 ?
Вот ситуация (очень упрощенная) ):
Клиент A использует python=3.8.1
(а также pandas=1.0.0
и pytables=3.6.1
). A записывает некоторый DataFrame, используя df.to_hdf(file, key)
.
Клиент B использует python=3.7.1
(и, как оказалось, pandas=0.25.1
и pytables=3.5.2
- но это не имеет значения). B пытается прочитать данные, записанные A, используя pd.read_hdf(file, key)
, и завершается неудачно с ValueError: unsupported pickle protocol: 5
.
Имейте в виду, это не происходит с чисто числовым кадром данных (например, pd.DataFrame(np.random.normal(size=(10,10)))
. Так вот воспроизводимый пример:
(base) $ conda activate py38
(py38) $ python
Python 3.8.1 (default, Jan 8 2020, 22:29:32)
[GCC 7.3.0] :: Anaconda, Inc. on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import pandas as pd
>>> df = pd.DataFrame(['hello', 'world']))
>>> df.to_hdf('foo', 'x')
>>> exit()
(py38) $ conda deactivate
(base) $ python
Python 3.7.4 (default, Aug 13 2019, 20:35:49)
[GCC 7.3.0] :: Anaconda, Inc. on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import pandas as pd
>>> df = pd.read_hdf('foo', 'x')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/opt/anaconda3/lib/python3.7/site-packages/pandas/io/pytables.py", line 407, in read_hdf
return store.select(key, auto_close=auto_close, **kwargs)
File "/opt/anaconda3/lib/python3.7/site-packages/pandas/io/pytables.py", line 782, in select
return it.get_result()
File "/opt/anaconda3/lib/python3.7/site-packages/pandas/io/pytables.py", line 1639, in get_result
results = self.func(self.start, self.stop, where)
File "/opt/anaconda3/lib/python3.7/site-packages/pandas/io/pytables.py", line 766, in func
return s.read(start=_start, stop=_stop, where=_where, columns=columns)
File "/opt/anaconda3/lib/python3.7/site-packages/pandas/io/pytables.py", line 3206, in read
"block{idx}_values".format(idx=i), start=_start, stop=_stop
File "/opt/anaconda3/lib/python3.7/site-packages/pandas/io/pytables.py", line 2737, in read_array
ret = node[0][start:stop]
File "/opt/anaconda3/lib/python3.7/site-packages/tables/vlarray.py", line 681, in __getitem__
return self.read(start, stop, step)[0]
File "/opt/anaconda3/lib/python3.7/site-packages/tables/vlarray.py", line 825, in read
outlistarr = [atom.fromarray(arr) for arr in listarr]
File "/opt/anaconda3/lib/python3.7/site-packages/tables/vlarray.py", line 825, in <listcomp>
outlistarr = [atom.fromarray(arr) for arr in listarr]
File "/opt/anaconda3/lib/python3.7/site-packages/tables/atom.py", line 1227, in fromarray
return six.moves.cPickle.loads(array.tostring())
ValueError: unsupported pickle protocol: 5
>>>
Примечание: я пытался также читать, используя pandas=1.0.0
(и pytables=3.6.1
) в python=3.7.4
. Это тоже не получается, поэтому я считаю, что это просто Python версия (писатель 3.8 против читателя 3.7), которая вызывает проблему. Это имеет смысл, поскольку протокол 5 рассола был представлен как PEP-574 для Python 3.8.