PyInstaller ImportError:没有名为spiderloader的模块

问题描述 投票:1回答:1

试图从我的exe项目创建Scrapy文件。我在main.py项目的根目录中创建了Scrapy文件:

from scrapy.crawler import CrawlerProcess
from engine_bot.engine_bot.spiders.main_spider import MainSpider


if __name__ == '__main__':
    process = CrawlerProcess({'BOT_NAME':'engine_bot',
    'SPIDER_MODULES':['engine_bot.engine_bot.spiders'],
    'NEWSPIDER_MODULE':'engine_bot.engine_bot.spiders',
    'ROBOTSTXT_OBEY':False,
    'DOWNLOAD_DELAY':0.20,
    'LOG_FILE':'scrapy.log',
    'LOG_LEVEL':'INFO',
    'ITEM_PIPELINES':{
    'engine_bot.engine_bot.pipelines.XmlExportPipeline': 300,
    }
    })
    process.crawl(MainSpider)
    process.start()

并创建了main.exepyinstaller --onefile main.py

当我运行main.exe时它会引发:

Traceback (most recent call last):
  File "bot\main.py", line 14, in <module>
  File "site-packages\scrapy\crawler.py", line 243, in __init__
  File "site-packages\scrapy\crawler.py", line 134, in __init__
  File "site-packages\scrapy\crawler.py", line 320, in _get_spider_loader
  File "site-packages\scrapy\utils\misc.py", line 44, in load_object
  File "importlib\__init__.py", line 37, in import_module
ImportError: No module named spiderloader
[10280] Failed to execute script main

没有--onefile尝试相同的结果。你知道该怎么办吗?

python windows python-2.7 scrapy pyinstaller
1个回答
0
投票

我使用pyinstaller -F filename.py --hidden-import spiderloader并且传递后这个案例也会卡在其他模块中,所以我添加了许多隐藏的导入。

对我来说这项工作。

© www.soinside.com 2019 - 2024. All rights reserved.