25

我想使用 Sphinx,这样它就可以为我的 python 代码自动生成一个 pydoc,但是我遇到了一个错误。我做错了什么?

conf.py狮身人面像配置文件

import sys
import os
from django.conf import settings
os.environ['DJANGO_SETTINGS_MODULE'] = '../cloud_server.settings'

sys.path.insert(0, os.path.abspath('../cloud_server/cloud_api'))

views.py django 文件

from django.contrib.auth.models import User, Group
from rest_framework import viewsets
from cloud_api.serializers import UserSerializer, GroupSerializer


class UserViewSet(viewsets.ModelViewSet):
    """
    API endpoint that allows users to be viewed or edited.
    """
    queryset = User.objects.all()
    serializer_class = UserSerializer


class GroupViewSet(viewsets.ModelViewSet):
    """
    API endpoint that allows users to be viewed or edited.
    """
    queryset = Group.objects.all()
    serializer_class = GroupSerializer

当我尝试制作 html 文件时抛出Typeerror错误。

    C:\Users\ogward\STUDPROJ\docs\code.rst:3: WARNING: autodoc: failed to import module u'views'; the following exception wa
s raised:
Traceback (most recent call last):
  File "C:\Python27\lib\site-packages\sphinx-1.2.2-py2.7.egg\sphinx\ext\autodoc.py", line 335, in import_object
    __import__(self.modname)
  File "C:\Users\ogward\STUDPROJ\cloud_server\cloud_api\views.py", line 1, in <module>
    from django.contrib.auth.models import User, Group
  File "C:\Python27\lib\site-packages\django\contrib\auth\__init__.py", line 6, in <module>
    from django.middleware.csrf import rotate_token
  File "C:\Python27\lib\site-packages\django\middleware\csrf.py", line 14, in <module>
    from django.utils.cache import patch_vary_headers
  File "C:\Python27\lib\site-packages\django\utils\cache.py", line 26, in <module>
    from django.core.cache import get_cache
  File "C:\Python27\lib\site-packages\django\core\cache\__init__.py", line 69, in <module>
    if DEFAULT_CACHE_ALIAS not in settings.CACHES:
  File "C:\Python27\lib\site-packages\django\conf\__init__.py", line 54, in __getattr__
    self._setup(name)
  File "C:\Python27\lib\site-packages\django\conf\__init__.py", line 49, in _setup
    self._wrapped = Settings(settings_module)
  File "C:\Python27\lib\site-packages\django\conf\__init__.py", line 128, in __init__
    mod = importlib.import_module(self.SETTINGS_MODULE)
  File "C:\Python27\lib\site-packages\django\utils\importlib.py", line 33, in import_module
    raise TypeError("relative imports require the 'package' argument")
TypeError: relative imports require the 'package' argument
looking for now-outdated files... none found
pickling environment... done
checking consistency... done
preparing documents... done
writing output... [ 50%] code
writing output... [100%] index

writing additional files... genindex search
copying static files... done
copying extra files... done
dumping search index... done
dumping object inventory... done
build succeeded, 1 warning.
4

5 回答 5

16

我是通过谷歌提出这个问题的,所以我会回答对我有帮助的(与问题没有直接关系)。

importlib用来动态导入由字符串给出的子包。

import importlib
module_name = 'subpackage.i.import'
special_module = importlib.import_module(module_name, package=None)

只需将其调整为

import importlib
module_name = 'subpackage.i.import'
special_module = importlib.import_module(module_name, package='my_current_pkg')
于 2017-08-28T08:53:56.217 回答
11

DJANGO_SETTINGS_MODULE预计是Python 模块标识符,而不是文件系统路径。查看该django/conf/__init__py文件,您的设置模块的相对路径似乎在那里不起作用。您需要将其移动到您的 中列出的目录下方sys.path,或者您应该将父目录添加到您的sys.path并从那里引用您的设置模块。

于 2014-03-04T16:03:46.460 回答
1

如果您在指定设置文件名的位置有错字,也可能会出现此错误。

于 2019-03-07T22:20:56.310 回答
1

您需要将项目路径添加到 sys 路径,就像

sys.path.append("C:\\Users\\ogward\\STUDPROJ") 
os.environ['DJANGO_SETTINGS_MODULE'] = '../cloud_server.settings'
 
于 2020-12-09T09:51:01.740 回答
0
  1. 可能是你在uwsgi.py中设置的设置不正确
  2. uwsgi.py 中的设置路径(XXXX 与 uwsgi.py 位于同一目录中):

    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "XXXX.settings")

于 2014-09-02T09:15:57.697 回答