- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 Django 2.0 中创建了一个通用 View 和序列化器,这样我就不必重复创建 CRUD View 或序列化器。
我的API应用程序的views.py文件
from rest_framework import generics, mixins
from rest_framework.serializers import ModelSerializer
class StandardListMixinCreateApiView(mixins.CreateModelMixin, generics.ListAPIView):
def post(self, request, *args, **kwargs):
return self.create(request, *args, **kwargs)
class StandardRudApiView(generics.RetrieveUpdateDestroyAPIView):
lookup_field = 'pk'
此函数设置每个启用模型的serializer.Meta.model
。`cls 参数是 StandardApiView 之一。
def get_adapted_class(cls, model_class, serializer_fields='__all__'):
class AdaptedSerializer(ModelSerializer):
class Meta:
model = model_class
fields = serializer_fields
class AdaptedView(cls):
model = model_class.__name__
queryset = model_class.objects.all()
serializer_class = AdaptedSerializer
return AdaptedView
我的 urls.py
from django.urls import re_path
from .views import *
from django.contrib.auth.models import Group, Permission
from .models import *
app_name = "api"
为其生成 CRUD View 的模型。
ENABLEDMODELS = [
Address,
Group,
Permission,
Customer,
Employee,
Commission,
BugReport,
FeatureRequest,
]
APILISTVIEWS = [get_adapted_class(
StandardListMixinCreateApiView,
model) for model in ENABLEDMODELS]
APIRUDVIEWS = [get_adapted_class(
StandardRudApiView,
model) for model in ENABLEDMODELS]
将每个创建的 ListView 的 url 路由添加到 urlpatterns
# List, create views
urlpatterns = [re_path(
f'^(?i){class_view.model}/',
class_view.as_view(),
name=f'{class_view.model}-list') for class_view in APILISTVIEWS]
# Retrive, update, delete views
urlpatterns += [re_path(
f'^(?i){class_view.model}/' + r'(?P<pk>\d+)',
class_view.as_view(),
name=f'{class_view.model}-rud') for class_view in APIRUDVIEWS]
错误消息
Environment:
Request Method: GET
Request URL: http://localhost:8000/api/address/
Django Version: 2.0.4
Python Version: 3.6.5
Installed Applications:
['django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'api']
Installed Middleware:
['django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware']
Traceback:
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\django\core\handlers\exception.py" in inner
35. response = get_response(request)
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\django\core\handlers\base.py" in _get_response
158. response = self.process_exception_by_middleware(e, request)
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\django\core\handlers\base.py" in _get_response
156. response = response.render()
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\django\template\response.py" in render
106. self.content = self.rendered_content
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\response.py" in rendered_content
72. ret = renderer.render(self.data, accepted_media_type, context)
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\renderers.py" in render
724. context = self.get_context(data, accepted_media_type, renderer_context)
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\renderers.py" in get_context
656. raw_data_post_form = self.get_raw_data_form(data, view, 'POST', request)
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\renderers.py" in get_raw_data_form
572. data = serializer.data.copy()
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\serializers.py" in data
560. ret = super(Serializer, self).data
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\serializers.py" in data
266. self._data = self.get_initial()
File "C:\Users\Steffen22\AppData\Local\Programs\Python\Python36\lib\site-packages\rest_framework\serializers.py" in get_initial
413. for field in self.fields.values()
Exception Type: AttributeError at /api/address/
Exception Value: 'str' object has no attribute 'values'
最佳答案
我找到了一个解决方案来重用我的标准 REST View 、序列化器并根据它们生成 url。
'api/views.py'
from rest_framework import generics, mixins
from rest_framework.serializers import ModelSerializer
class StandardListMixinCreateApiView(mixins.CreateModelMixin, generics.ListAPIView):
def post(self, request, *args, **kwargs):
return self.create(request, *args, **kwargs)
class StandardRudApiView(generics.RetrieveUpdateDestroyAPIView):
lookup_field = 'pk'
def get_adapted_class(cls, model_class, serializer_fields='__all__'):
class AdaptedView(cls):
model = model_class.__name__
我必须重写 get_serializer_class 函数,而不是设置 serializer_class 属性。
def get_serializer_class(self):
class BaseSerializer(ModelSerializer):
class Meta:
model = model_class
fields = serializer_fields
return BaseSerializer
def get_queryset(self):
return model_class.objects.all()
return AdaptedView
那些标准的ApiViews很容易使用,你可以创建一个新的django模型并将模型类添加到ENABLEDMODELS列表中
'api/urls.py'
from django.urls import re_path
from .views import *
from django.contrib.auth.models import Group, Permission
from .models import *
app_name = "api"
ENABLEDMODELS = [
Address,
Group,
Permission,
Customer,
Employee,
Commission,
BugReport,
FeatureRequest,
]
APILISTVIEWS = [get_adapted_class(
StandardListMixinCreateApiView,
model) for model in ENABLEDMODELS]
APIRUDVIEWS = [get_adapted_class(
StandardRudApiView,
model) for model in ENABLEDMODELS]
在 2.0 以下的 Django 版本中,path/re_path 方法称为 url,如果您更改它也应该在旧版本中工作。
re_path 方法用于 Django 2.0 中的正则表达式路由
# List, create views
urlpatterns = [re_path(
f'^(?i){class_view.model}/',
class_view.as_view(),
name=f'{class_view.model}-list') for class_view in APILISTVIEWS]
# Retrive, update, delete views
urlpatterns += [re_path(
f'^(?i){class_view.model}/' + r'(?P<pk>\d+)',
class_view.as_view(),
name=f'{class_view.model}-rud') for class_view in APIRUDVIEWS]
关于python - Django 2.0,一级类 View ,AttributeError : 'str' object has no attribute 'values' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49961120/
你信吗?我有一个这样的循环(请原谅任何错误,我不得不大量编辑大量信息和变量名称,相信我它有效)。 ...旧示例已删除,请参见下面的代码... 如果我将那些中间的 str = "Blah\(odat.c
我正在做一个本地测试来比较 C# 中 String 和 StringBuilder 的 Replace 操作性能,但是对于 String 我使用了以下代码: String str = "String
我想知道为什么str += "A"和 str = str + "A"有不同的表现。 在实践中, string str = "cool" for(int i = 0; i approximately
我有一个类型列表 [("['106.52.116.101']", 1), ("['45.136.108.85']", 1)] 并想将其转换为 [('106.52.116.101', 1), ('45.
我有一个类型列表 [("['106.52.116.101']", 1), ("['45.136.108.85']", 1)] 并想将其转换为 [('106.52.116.101', 1), ('45.
我正在遍历 HashMap并通过一些本地变量中的模式匹配将值放入其中。 委托(delegate)者 fn lyrics_no_bottles(song_template:&mut String){
如果字符串(短语)中只有元音,它(对我而言)说True;否则说 False。我不明白为什么它总是返回 False,因为 (x >= x) 总是返回 True。我感谢任何人检查此查询的解决方案。 (st
我有代码以某种方式转换字符串引用,例如取第一个字母 trait Tr { fn trim_indent(self) -> Self; } impl Tr for &'a str { f
我正在学习指针,这是我的代码。我定义了一个指向 char(实际上是字符串)的指针 *str 和一个指向 int *a 的指针,它们的定义方式相同。我认为 str 和 a 都应该是一个地址,但是当我试图
为什么我会收到错误消息?我已经正确添加了类型,对吗? Invalid index type "str" for "Union[str, Dict[str, str]]"; expected type
你知道下面两个函数是否等价吗? function validate(str) { return ( ['null','','undefined'].indexOf(str) [v, valida
我正在解决这里的 Dataquest 问题:https://app.dataquest.io/m/293/data-cleaning-basics/5/removing-non-digit-chara
我有一个字符串列表,如下所示: ["A TB", "A-R TB", "B TB", "B-R TB", "C TB", "C-R TB"...] 但字符串的顺序是随机的。我如何编写一个将元素配对的函
我正在尝试将此函数从使用 split 改为使用 str.extract (正则表达式)。 def bull_lev(x): spl = x.rsplit(None, 2)[-2].strip(
给定这样的数据结构: [{'a':1, 'b': 2}, {'c':3 }, {'a':4, 'c':9}, {'d':0}, {'d': 0, 'b':6}] 目标是解析数据以产生: {'a': 2
给定这样的数据结构: [{'a':1, 'b': 2}, {'c':3 }, {'a':4, 'c':9}, {'d':0}, {'d': 0, 'b':6}] 目标是解析数据以产生: {'a': 2
s = 'someString' s = QTreeWidgetItem(s) print(s.text(0)) # 0 being 'column' 输出: 's' 如果我对另一
黑白有什么区别: function(char* str ) function(char* str[] ) function(char str[] ) 它们是如何被调用的(通过什么类型的string/c
我试过谷歌搜索但找不到准确的答案,所以请允许我尝试在这里提问。如果问题看起来不合适,请告诉我,我会删除它。 在 JS 中,您可以通过三种不同的方式编写特定的内置功能: 字符串长度 str.toStri
我有这段代码(我的 strlen 函数) size_t slen(const char *str) { size_t len = 0; while (*str) {
我是一名优秀的程序员,十分优秀!