Как передать 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