Как передать kwargs в URL в django
В django doc функция url подобна этой функции
url(regex, view, kwargs=None, name=None, prefix='')
У меня есть это
url(r'^download/template/(?P<object_id>\d+)/$', views.myview().myfunction,model=models.userModel, name="sample")
Это мой взгляд
class myview(TemplateView):
def myfunction(self,request, object_id, **kwargs):
model = kwargs['model']
Я получаю эту ошибку
url() got an unexpected keyword argument 'model'
Ответы
Ответ 1
Вы пытаетесь передать аргумент ключевого слова model
в функцию url()
; вам нужно передать вместо аргумента kwargs
(он принимает словарь):
url(r'^download/template/(?P<object_id>\d+)/$', views.myview().myfunction,
kwargs=dict(model=models.userModel), name="sample")
Ответ 2
Это:
url(r'^download/template/(?P<object_id>\d+)/$', views.myview().myfunction,model=models.userModel, name="sample")
Должно быть:
url(r'^download/template/(?P<object_id>\d+)/$', views.myview.as_view(model=models.userModel), name="sample")
См. docs
Ваша текущая реализация не является потокобезопасной. Например:
from django import http
from django.contrib.auth.models import User
from django.views import generic
class YourView(generic.TemplateView):
def __init__(self):
self.foo = None
def your_func(self, request, object_id, **kwargs):
print 'Foo', self.foo
self.foo = 'bar'
return http.HttpResponse('foo')
urlpatterns = patterns('test_app.views',
url(r'^download/template/(?P<object_id>\d+)/$', YourView().your_func,
kwargs=dict(model=User), name="sample"),
)
Ожидаете ли вы печати "Foo None"? Будьте осторожны, потому что экземпляр разделяется между запросами:
Django version 1.4.2, using settings 'django_test.settings'
Development server is running at http://127.0.0.1:8000/
Quit the server with CONTROL-C.
Foo None
[03/Dec/2012 08:14:31] "GET /test_app/download/template/3/ HTTP/1.1" 200 3
Foo bar
[03/Dec/2012 08:14:32] "GET /test_app/download/template/3/ HTTP/1.1" 200 3
Итак, когда он не является потокобезопасным, вы не можете предположить, что он будет в чистом состоянии при запуске запроса - в отличие от использования as_view().
Ответ 3
Я полагаю, что у вас будет такая же функциональность (и избежать проблем с потоками), если вы сделали это в своем views.py
from django.views.generic import TemplateView
from .models import userModel
class myview(TemplateView):
def myfunction(self, request, object_id, *args, **kwargs):
model = userModel
# ... Do something with it