django集成swagger报错 TypeError:Expected a `coreapi.Document` instance'

rest_framework_swagger报错 TypeError:Expected a `coreapi.Document` instance'

python相关信息

python 3.7.3
django 2.1.8
django-rest-swagger 2.2.0
djangorestframework 3.10.2
coreapi 2.3.3

settings.py文件信息

INSTALLED_APPS = [

‘api’,
‘rest_framework’,
‘rest_framework_swagger’,
]

REST_FRAMEWORK = {
‘DEFAULT_PERMISSION_CLASSES’: [
‘rest_framework.permissions.IsAuthenticated’,
]
}

urls.py文件信息

from django.contrib import admin
from django.urls import path
from django.conf.urls import include
from rest_framework import routers
from api import views
from rest_framework.schemas import get_schema_view
from rest_framework_swagger.renderers import SwaggerUIRenderer, OpenAPIRenderer

router = routers.DefaultRouter()
router.register(‘users’, views.UserViewSet, base_name=‘user’)
router.register(‘groups’, views.GroupViewSet, base_name=‘group’)

schema_view = get_schema_view(title=‘API’, renderer_classes=[SwaggerUIRenderer, OpenAPIRenderer])

urlpatterns = [
path(‘admin/’, admin.site.urls),
path(’’, include(router.urls)),
path(‘api-auth/’, include(‘rest_framework.urls’, namespace=‘rest_framework’)),
path(‘docs/’, schema_view, name=‘docs’),
]

报错信息

Internal Server Error: /docs/

Traceback (most recent call last):
File “D:\python\lib\site-packages\django\core\handlers\exception.py”, line 34, in inner
response = get_response(request)
File “D:\python\lib\site-packages\django\core\handlers\base.py”, line 156, in _get_response
response = self.process_exception_by_middleware(e, request)
File “D:\python\lib\site-packages\django\core\handlers\base.py”, line 154, in _get_response
response = response.render()
File “D:\python\lib\site-packages\django\template\response.py”, line 106, in render
self.content = self.rendered_content
File “D:\python\lib\site-packages\rest_framework\response.py”, line 70, in rendered_content
ret = renderer.render(self.data, accepted_media_type, context)
File “D:\python\lib\site-packages\rest_framework_swagger\renderers.py”, line 54, in render
self.set_context(data, renderer_context)
File “D:\python\lib\site-packages\rest_framework_swagger\renderers.py”, line 70, in set_context
renderer_context=renderer_context
File “D:\python\lib\site-packages\rest_framework_swagger\renderers.py”, line 34, in render
return OpenAPICodec().encode(data, **options)
File “D:\python\lib\site-packages\rest_framework_swagger\renderers.py”, line 16, in encode
raise TypeError(‘Expected a coreapi.Document instance’)
TypeError: Expected a coreapi.Document instance

求大神帮我解决

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: 这个错误是由于uwsgi.py文件的main()函数定义时没有指定参数导致的。在使用uwsgi启动Django时,main()函数通常不需要接受任何参数。 要解决这个问题,可以按照以下步骤进行操作: 1. 打开uwsgi.py文件,找到main()函数的定义。 2. 确保函数定义如下所示: ```python def main(): ``` 3. 检查代码中是否有尝试传递参数给main()函数的部分。如果有,将其删除或者注释掉。 4. 保存并关闭uwsgi.py文件。 5. 再次使用uwsgi启动Django应用程序,应该不再出现"TypeError: main() takes 0 positional arguments"的错误。 这个错误的原因是uwsgi.py文件中的main()函数定义不符合标准,它被设计为不需要任何参数。修复这个问题通常很简单,只需修改main()函数的定义即可。当然,如果uwsgi.py文件是从外部源获取的,则需要查阅其文档或联系开发者以获取正确的使用方式。 ### 回答2: 这个错误是因为在启动Django中的uwsgi.py文件时,main()函数接受了0个位置参数。在uwsgi.py文件中的main()函数原本不需要接受任何参数,所以出现该错误可能是由于uwsgi的配置存在问题。 解决该问题的方法如下: 1. 检查uwsgi.py文件中的main()函数是否接受了位置参数。如果接受了参数,可以将其修改为不接受任何参数的形式。 2. 检查uwsgi的配置文件是否正确。在uwsgi的配置文件中,应该指定uwsgi.py作为应用程序的入口点,并且不应该传递任何位置参数给uwsgi.py。 3. 确保在启动uwsgi时没有向uwsgi.py传递任何位置参数。在命令行中执行启动uwsgi的命令时,不要传递任何参数给uwsgi.py。 如果以上方法都没有解决问题,可能需要进一步检查uwsgi的版本是否与Django兼容,并尝试更新uwsgi或Django的版本。 总结一下,TypeError: main() takes 0 positional arguments错误是由于uwsgi.py文件的main()函数接受了位置参数而引起的。根据具体情况,可以通过修改main()函数的参数或检查uwsgi的配置来解决该问题。 ### 回答3: 这个错误是因为uwsgi.py文件定义的main函数没有接收任何参数,但是在该文件被调用时却传入了参数。 要解决这个问题,我们需要检查uwsgi.py文件中的main函数的定义,确保没有任何参数。您可以按照下面的步骤操作: 1. 打开uwsgi.py文件,查找main函数的定义。 2. 检查main函数的定义是否类似于以下形式: def main(): # 函数体 3. 如果在函数定义的括号内存在任何参数,您需要将其删除,使其变为: def main(): # 函数体 4. 保存uwsgi.py文件并重新启动Django应用程序。 这样,当您再次启动uwsgi.py文件时,不会再出现"TypeError: main() takes 0 positional arguments"这个错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值