python - 无法导入 Scrapy 的设置模块或其 scrapy.cfg

标签 python django environment-variables scrapy

这是一篇很长的文章,但经过广泛研究后我找不到解决方案。我在 OSX 10.8 上有一个 Django 1.4.1/Scrapy 0.14.4 混合项目,我使用 Django 项目的 manage.py 命令控制 Scrapy,如 here 所述。 .例如,调用

python manage.py scrapy crawl example_spider 

工作没有问题。现在我要设置 scrapyd web 服务来部署我的蜘蛛程序。但是,当我执行

python manage.py scrapy server

然后我得到这个异常:

scrapy.exceptions.NotConfigured: Unable to find scrapy.cfg file to infer project data dir

所以,显然 Scrapy 找不到 scrapy.cfg 文件,因为我没有从 Scrapy 项目中执行它。但是,其他 Scrapy 命令有效,因为在我的 Django 项目的 settings.py 中,我执行了以下操作:

sys.path.append('/absolute/path/to/my/Scrapy/project')
os.environ['SCRAPY_SETTINGS_MODULE'] = 'my_scrapy_project_name.settings'

问题1:为什么Scrapy在我的设置中检测不到scrapy.cfg文件?我该如何解决这个问题?


由于上面提到的东西不起作用,我尝试在我的 Scrapy 项目目录中使用 scrapy 命令来运行 scrapyd 服务器。从我的 Scrapy 项目的顶级目录执行 scrapy server 会产生以下结果:

$ scrapy server
UserWarning: Cannot import scrapy settings module my_scrapy_project_name.settings
warnings.warn("Cannot import scrapy settings module %s" % scrapy_module)
2012-08-31 21:58:31+0200 [-] Log opened.
2012-08-31 21:58:32+0200 [-] Scrapyd web console available at http://localhost:6800/
2012-08-31 21:58:32+0200 [Launcher] Scrapyd started: max_proc=8, runner='scrapyd.runner'
2012-08-31 21:58:32+0200 [-] Site starting on 6800
2012-08-31 21:58:32+0200 [-] Starting factory <twisted.web.server.Site instance at 0x101dd3d88> 

服务器运行没有问题,但是找不到我的Scrapy项目的settings.py文件,因为没有设置相应的环境变量。这就是我在终端中执行以下操作的原因:

export PYTHONPATH=/absolute/path/to/my/Scrapy/project
export SCRAPY_SETTINGS_MODULE=my_scrapy_project_name.settings

不幸的是,这两个命令没有效果。每当我执行 scrapy server(或任何其他 Scrapy 命令)时,我都会收到 Scrapy 无法导入其项目设置模块的消息。

我的scrapy.cfg目前只有以下内容:

[settings]
default = my_scrapy_project_name.settings

[deploy:scrapyd]
url = http://localhost:6800/
project = my_scrapy_project_name

当我尝试将我的 Scrapy 项目部署到 scrapyd 服务器时,一开始它似乎可以工作,但后来我意识到没有一个蜘蛛被上传,可能是因为设置文件无法上传被检测到。这是控制台输出:

$ scrapy deploy scrapyd -p my_scrapy_project_name
/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-
packages/scrapy/utils/project.py:17: UserWarning: Cannot import scrapy
settings module my_scrapy_project_name.settings
 warnings.warn("Cannot import scrapy settings module %s" %
scrapy_module)
Building egg of event_crawler-1346531706
'build/lib' does not exist -- can't clean it
'build/bdist.macosx-10.6-intel' does not exist -- can't clean it
'build/scripts-2.7' does not exist -- can't clean it
zip_safe flag not set; analyzing archive contents...
Deploying event_crawler-1346531706 to http://localhost:6800/addversion.json
Server response (200):
{"status": "ok", "project": "my_scrapy_project_name", "version": "1346531706", "spiders": 0}

问题2:如何正确导出上面的路径和环境变量,使这个警告消失?

问题 3:虽然 scrapyd 服务器似乎工作正常,但我如何才能正确上传我的蜘蛛程序?

非常感谢!

最佳答案

如果您查看 code branch that raises this exceptiondefinition of the closest_scrapy_cfg function它调用的唯一地方是 scrapy 寻找你的 scrapy.cfg 是在你运行命令的目录和任何父目录中。您可以在您的 manage.py 中运行 os.chdir,或者将您的 scrapy.cfg 移动到您正在运行的目录。

关于python - 无法导入 Scrapy 的设置模块或其 scrapy.cfg,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12221937/

相关文章:

python - 如何将 'using' DB 传递给 django 连接对象

django - 如何使用 django 创建 oauth (REST) API(如 twitter 或 foursquare )?

hadoop - Hadoop环境变量:何时初始化?

python - 使用临时环境变量运行 Python 脚本

java - 安装了两个版本的 Java 时出现错误 Python tabula

python - 如何防止 pandas.Dataframe.to_latex 在 latex 公式字符(即美元符号/括号)之前添加转义\字符?

python - 是否可以在 Python 中加速这个循环?

python - Pandas 合并索引和列上的多个数据帧

django - 如何仅允许登录用户连接到 Django Channels 中的 websocket?

Django:防止在表单集中保存空表单