В Datashader есть мгновенная ошибка

Я использовал пакет python datashader 0.5.0 для построения информации о плотности населения, как правило, следуя руководству https://www.continuum.io/blog/developer-blog/analyzing-and-visualizing-big-data-Interactively-your-laptop-datashading-2010-us. Я установил даташейдер, используя conda install -c bokeh datashader=0.5.0.

Все было хорошо. Хотя это, возможно, не связано, все, казалось, сломалось, как только я установил пакеты haloviews и geoviews. После установки этих дополнительных пакетов я больше не могу импортировать datashader, и мой когда-то рабочий код больше не запускается. При импорте datashader я получаю следующую ошибку: AttributeError: модуль 'snappy' не имеет атрибута 'compress'

Я использую windows 10, anaconda python 3.5.3.

Возможно, я пойду не в ту кроличью нору, но я подумал, что, возможно, дело в быстрой упаковке. Я запустил «conda install -c conda-forge snappy = 1.1.4». Список conda показывает, что установлен snappy. Snappy импортирует. Объект snappy.compress не найден. Моя проблема, похоже, связана со следующим сообщением SO, поскольку у меня также была ошибка fastparquet при попытке geoviews: ошибка мгновенного импорта при импорте fastparquet в python

При запуске import snappy print(snappy.__filename__) выдает следующую ошибку:

---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
<ipython-input-5-b8565733b383> in <module>()
----> 1 import snappy; print(snappy.__file__)

AttributeError: module 'snappy' has no attribute '__file__'

Я также попытался удалить через conda и pip на всякий случай. По-прежнему никакой радости.

Запуск «pip install python-snappy» приводит к ошибке «сбой сборки для python-snappy», которой предшествует «ошибка: требуется Microsoft Visual C ++ 14.0 ...» Итак, я пошел и получил «Microsoft Visual C ++ Redistributable для Visual Studio. 2017 "и запустил его, но без изменений.

Есть мысли о том, как это решить? Для справки, полная ошибка при импорте даташейдера выглядит следующим образом:

--------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
<ipython-input-7-3d7b1ff9e530> in <module>()
----> 1 import datashader

C:\Python\lib\site-packages\datashader\__init__.py in <module>()
      3 __version__ = '0.5.0'
      4 
----> 5 from .core import Canvas
      6 from .reductions import (count, any, sum, min, max, mean, std, var, count_cat,
      7                          summary)

C:\Python\lib\site-packages\datashader\core.py in <module>()
      3 import numpy as np
      4 from datashape.predicates import istabular
----> 5 from odo import discover
      6 from xarray import DataArray
      7 

C:\Python\lib\site-packages\odo\__init__.py in <module>()
     63     from .backends.url import URL
     64 with ignoring(ImportError):
---> 65     from .backends.dask import dask
     66 
     67 

C:\Python\lib\site-packages\odo\backends\dask.py in <module>()
      8 
      9 from dask.array.core import Array, from_array
---> 10 from dask.bag.core import Bag
     11 import dask.bag as db
     12 from dask.compatibility import long

C:\Python\lib\site-packages\dask\bag\__init__.py in <module>()
      1 from __future__ import absolute_import, division, print_function
      2 
----> 3 from .core import (Bag, Item, from_sequence, from_url, to_textfiles, concat,
      4                    from_delayed, map_partitions, bag_range as range,
      5                    bag_zip as zip, bag_map as map)

C:\Python\lib\site-packages\dask\bag\core.py in <module>()
     30 
     31 from ..base import Base, normalize_token, tokenize
---> 32 from ..bytes.core import write_bytes
     33 from ..compatibility import apply, urlopen
     34 from ..context import _globals, defer_to_globals

C:\Python\lib\site-packages\dask\bytes\__init__.py in <module>()
      2 
      3 from ..utils import ignoring
----> 4 from .core import read_bytes, open_files, open_text_files
      5 
      6 from . import local

C:\Python\lib\site-packages\dask\bytes\core.py in <module>()
      7 from warnings import warn
      8 
----> 9 from .compression import seekable_files, files as compress_files
     10 from .utils import (SeekableFile, read_block, infer_compression,
     11                     infer_storage_options, build_name_function)

C:\Python\lib\site-packages\dask\bytes\compression.py in <module>()
     30 with ignoring(ImportError):
     31     import snappy
---> 32     compress['snappy'] = snappy.compress
     33     decompress['snappy'] = snappy.decompress
     34 

AttributeError: module 'snappy' has no attribute 'compress'

person Docuemada    schedule 04.07.2017    source источник
comment
Примечание: при удалении snappy я удаляю snappy 1.1.4-vc14_0. Использование установки с помощью conda install .org / packages / 4c / 8f / или с conda install python-snappy = 0.5.1 приводит к PackageNotFoundError: пакет отсутствует в текущих каналах win-64 ...   -  person Docuemada    schedule 04.07.2017


Ответы (1)


Оказывается, что при добавлении пакетов что-то испортило быструю установку. Я последовал этому решению: Как установить быстрые библиотеки C в Windows 10 для использования с python-snappy в Anaconda? Это была мгновенная ошибка, а не проблема с даташадером, но я оставлю сообщение на случай, если у кого-то есть та же серия вопросов.

person Docuemada    schedule 04.07.2017