Bitbucket的管道无法识别已安装的python库

时间:2019-11-12 19:45:51

标签: python bitbucket python-sphinx bitbucket-pipelines

目标:我正在尝试在位桶管道中生成sphinx文档。

问题:尽管有关管道的所有工作均正常进行,但狮身人面像似乎在查找某些模块方面存在问题:

WARNING: autodoc: failed to import module ... from module ...;
the following exception was raised: No module named 'pandas'

如消息所示,这是因为找不到pandas

通常在sphinx需要项目中调用的库但未安装该库时发生。因此,我安装了requirements.txt中列出的所有模块,当然包括pandas。但是,我仍然收到相同的警告。

后果::这些警告会使生成的html文件为空(只有模块名称可能会显示在其中)。


关于管道的更多信息:我的管道包括3个步骤:

  1. 安装python moduels:pip install -r requirements.txt,(成功完成)
  2. 生成sphinx文档(成功完成,并带有上述警告)
  3. 将结果同步到远程服务器(与问题无关)

在这里您可以看到我的管道配置:bitbucket-pipelines.yml


故障排除1 :我已经在机器上以完全相同的配置执行了这个项目,并且没有收到有关缺少模块的警告。如果我使用另一个pandas(例如)缺失的virtualenv,则狮身人面像就会开始抱怨它,如上所示。

故障排除2 :对此类问题的典型应对措施是检查sys.path中的conf.py。 (在我的情况下)找不到模块与我在sys.path中添加conf.py的方式无关。如果是这种情况,sphinx可能会在所有模块上遇到问题。

1 个答案:

答案 0 :(得分:1)

每个管道步骤都在一个单独的Docker容器中运行,这就是为什么在第二步中缺少依赖项的原因。您需要在安装依赖项的同一步骤中运行sphinx,例如:

image: python:3.6.8

pipelines:
  branches:
    master:
        - step:
            name: doc generator
            trigger: manual
            caches:
              - pip
            script:
              - apt-get update && apt-get -y install python-sphinx

              # INSTALL YOUR DEPENDENCIES HERE
              - pip install -r requirements.txt  

              - pip install sphinx_rtd_theme
              - cd sphinxdocs
              - make clean
              - sphinx-apidoc -o . ..
              - make html
            artifacts:
              - sphinxdocs/_build/html/**