我是Scrapy的新手,只對Python有一個基本的理解。
運行Scrapy教程時發生錯誤。
我有一個Windows 7操作系統,64位和32位的Python 2.7.12安裝
步驟到目前爲止,我已經採取Scrapy教程扭曲錯誤
- 隨後的步驟按照安裝頁面,並建立了一個虛擬環境「scrapy 「
- 激活虛擬環境
- 安裝scrapy(所有的依賴似乎也已經安裝了罰款,包括pywin,32位版本)
- 冉步驟按照教程頁面
- 創建的文件
quotes_spider.py
,與上tutorial page 給出從scrapy \腳本代碼
scrapy startproject tutorial
- \教程中,我跑了
scrapy crawl quotes
並得到了以下錯誤(scrapy) F:\My Projects\scrapy\Scripts\tutorial>scrapy crawl quotes 2016-11-05 14:21:59 [scrapy] INFO: Scrapy 1.2.1 started (bot: tutorial) 2016-11-05 14:21:59 [scrapy] INFO: Overridden settings: {'NEWSPIDER_MODULE': 'tutorial.spiders', 'SPIDER_MODULES': ['tutorial.spiders'], 'ROBOTSTXT_OBEY': True, 'BOT_NAME': 'tutorial'} 2016-11-05 14:21:59 [scrapy] INFO: Enabled extensions:'scrapy.extensions.logstats.LogStats','scrapy.extensions.telnet.Telne tConsole', 'scrapy.extensions.corestats.CoreStats'] Unhandled error in Deferred: 2016-11-05 14:21:59 [twisted] CRITICAL: Unhandled error in Deferred: 2016-11-05 14:21:59 [twisted] CRITICAL: Traceback (most recent call last): File "f:\myproj~1\scrapy\lib\site-packages\twisted\internet\defer.py", line 12 60, in _inlineCallbacks result = g.send(result) File "f:\myproj~1\scrapy\lib\site-packages\scrapy\crawler.py", line 90, in crawl six.reraise(*exc_info) File "f:\myproj~1\scrapy\lib\site-packages\scrapy\crawler.py", line 72, in crawl self.engine = self._create_engine() File "f:\myproj~1\scrapy\lib\site-packages\scrapy\crawler.py", line 97, in _create_engine return ExecutionEngine(self, lambda _: self.stop()) File "f:\myproj~1\scrapy\lib\site-packages\scrapy\core\engine.py", line 68, in __init__ self.downloader = downloader_cls(crawler) File "f:\myproj~1\scrapy\lib\site- packages\scrapy\core\downloader\__init__.py" , line 88, in __init__ self.middleware = DownloaderMiddlewareManager.from_crawler(crawler) File "f:\myproj~1\scrapy\lib\site-packages\scrapy\middleware.py", line 58, in from_crawler return cls.from_settings(crawler.settings, crawler) File "f:\myproj~1\scrapy\lib\site-packages\scrapy\middleware.py", line 34, in from_settings mwcls = load_object(clspath) File "f:\myproj~1\scrapy\lib\site-packages\scrapy\utils\misc.py", line 44, in load_object mod = import_module(module) File "c:\python27\Lib\importlib\__init__.py", line 37, in import_module__import__(name) File "f:\myproj~1\scrapy\lib\site- packages\scrapy\downloadermiddlewares\retry.py", line 23, in <module> from scrapy.xlib.tx import ResponseFailed File "f:\myproj~1\scrapy\lib\site-packages\scrapy\xlib\tx\__init__.py", line 3, in <module> from twisted.web import client File "f:\myproj~1\scrapy\lib\site-packages\twisted\web\client.py", line 42, in <module> from twisted.internet.endpoints import TCP4ClientEndpoint, SSL4ClientEndpoint File "f:\myproj~1\scrapy\lib\site-packages\twisted\internet\endpoints.py", line 36, in <module> from twisted.internet.stdio import StandardIO, PipeAddress File "f:\myproj~1\scrapy\lib\site-packages\twisted\internet\stdio.py", line 30, in <module> from twisted.internet import _win32stdio File "f:\myproj~1\scrapy\lib\site- packages\twisted\internet\_win32stdio.py", line 9, in <module> import win32api ImportError: No module named win32api
這是很相似的錯誤討論here但建議的解決方案似乎並沒有解決。 pywin安裝在我的全局環境C:Python27 \ Lib \ site-packages中,但它並沒有出現在我的虛擬環境中。我不知道如何將它安裝在我的虛擬env中,因爲pywin可執行文件似乎只允許在C下安裝。在此先感謝您的幫助!在虛擬ENV
我的PIP列表
ATTRS == 16.2.0
CFFI == 1.8.3
不斷== 15.1.0
密碼== 1.5.2
cssselect == 1.0。 0
enum34 == 1.1.6
IDNA == 2.1
增量== 16.10.1
IPADDRESS == 1.0.17
LXML == 3.6.4
parsel == 1.0.3
pyasn1 == 0.1.9
pyasn1模塊== 0.0.8
pycparser == 2.17
PyDispatcher == 2.0.5
pyOpenSSL == 16.2.0
queuelib == 1.4.2
Scrapy == 1.2.1
服務身份== 16.0.0
6 == 1.10.0
扭曲== 16.5.0
w3lib == 1.15.0
zope.interface == 4.3.2
嘿任何想法,我從SourceForge下載的WIN32API(通過pypiwin32安裝)和pywin32是否在本質上是一回事嗎?所以我不會有更多的錯誤?只是問,因爲python32在Scrapy安裝頁面上被記錄爲必不可少的。謝謝你的幫助! –
@CraigDsouza是的,它本質上是一回事。 'pypiwin32'就是它在'pypi'(PYthon包索引)上的調用方式,你可以使用'pip'包管理系統來下載和構建它。 – Granitosaurus