簡體   English   中英

django 1.8:XView缺少QuerySet。 定義XView.model,XView.queryset,

[英]django 1.8:XView is missing a QuerySet. Define XView.model, XView.queryset,

轉到url:/result_list.html時出現錯誤。 但是views.py中確實存在queryset,那么還有其他原因嗎? 提前致謝。 該功能基於用戶提交的表單,然后過濾數據庫並在result_list.html中顯示表單條目和數據庫結果。

追溯

File "C:\Python27\lib\site-packages\django-1.8.3-py2.7.egg\django\core\handlers\base.py" in get_response
  132.                     response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "C:\Python27\lib\site-packages\django-1.8.3-py2.7.egg\django\views\generic\base.py" in view
  71.             return self.dispatch(request, *args, **kwargs)
File "C:\Python27\lib\site-packages\django-1.8.3-py2.7.egg\django\views\generic\base.py" in dispatch
  89.         return handler(request, *args, **kwargs)
File "C:\Python27\lib\site-packages\django-1.8.3-py2.7.egg\django\views\generic\list.py" in get
159.         self.object_list = self.get_queryset()
File "C:\Users\user\Desktop\SCOR\result\views.py" in get_queryset
70.         return super(ResultView,self).get_queryset()

get_queryset 44中的文件“ C:\\ Python27 \\ lib \\ site-packages \\ django-1.8.3-py2.7.egg \\ django \\ views \\ generic \\ list.py”。'cls':self。 上課 名稱
異常類型:在/ result_list /處配置不正確異常值:ResultView缺少QuerySet。 定義ResultView.model,ResultView.queryset或覆蓋ResultView.get_queryset()。

以下是摘要:

網址

from result.views import ResultView,InputFormView
from django.views.generic import TemplateView,FormView,ListView

urlpatterns = patterns('',    
    url(r'^result_list/$',ResultView.as_view(),name='result'),
    url(r'^input/$',InputFormView.as_view(),name='input'), 
)

views.py

from result.forms import InputForm
from result.models import Result,Input
from django.views.generic.list import ListView
from django.views.generic import FormView
....

@csrf_exempt

class InputFormView(FormView):
    template_name = 'inputform.html'
    form = InputForm

    def get_success_url(self):  /*redirect to result page with submitted form information*/
        return ''.join(
            [
                reverse('dupont'),
                '?company=',self.request.POST.get('company'),
                '?region=',self.request.POST.get('region')
            ]
        )

class ResultView(ListView):
    context_object_name = 'result_list'
    template_name = 'result_list.html'

    def get_context_data(self, **kwargs):
        context = super(ResultView, self).get_context_data(**kwargs)
        return context

    def get_queryset(self):
        if self.request.method == 'POST':
            form = InputForm(self.request.POST)
            if form.is_valid():
                company = form.cleaned_data['company']
                region = form.cleaned_data['region']

/---Based on form entry, do the filter on the database-----/

                queryset=Result.objects.filter(region=region,company=company)
                sales=Result.objects.filter(queryset).aggregate(Sum('sales'))
                employee=Result.objects.filter(queryset).aggregate(Sum('employee'))
                departments=Result.objects.filter(queryset).aggregate(Sum('departments'))

                form.save()

                return render(request,'result_list.html',{'company':company},{'region':region},{'employee':employee},{'sales':sales},{'departments':departments})

            else:
                print form.errors
        else:
            form=InputForm()                   
        return super(ResultView,self).get_queryset()

result_list.html

<div class="basicinfo">         <!--Entry Form information submitted by user-->

    <table border="1" cellpadding="1">
    <tr>
        <td align="left">Company</td>
        <td>{{company}}</td>
    </tr>
    <tr>
        <td align="left">Region</td>
        <td>{{region}}</td>
    </tr>
  </table>

<!--Showing the filtered result in database-->  
<td><table border="0" cellspacing="10" cellpadding="10">
<tr><b>Sales</b></tr>
<td bgcolor="#F0F0F0"> {{sales}}</td>

</tr>
<tr><b>Employee</b></tr>
<tr>
<td bgcolor="#F0F0F0"> {{employee}}</td>

</tr>
<tr><b>Departments</b></tr>
<td bgcolor="#F0F0F0"> {{departments}}</td>
</td></table>

根據solarissmoke和pythad的建議的版本2.0 views.py

class InputFormView(FormMixin,DetailView):
    template_name = 'inputform.html'
    form = InputForm

    def post(self, request, *args, **kwargs):
        self.object = self.get_object()
        form=self.get_form()
        if form.is_valid():
            return self.form_valid(form)
        else:
            return self.form_invalid(form)
            print form.errors

    def form_valid(self, form):
        company = form.cleaned_data['company']
        region = form.cleaned_data['region']

        return super(ResultView,self).form_valid(form) 《Q1:---If here to return to ResultView or InputFormView?--->

    def get_success_url(self):   #Redirect to result_list.html
        return reverse('result', kwargs={'pk': self.object.pk})


class ResultView(MultipleObjectMixin,DetailView):
    context_object_name = 'result_list'
    template_name = 'result_list.html'

    <---Q2: How can I get the form data entry from InputFormView?-->

    def get(self, request, *args, **kwargs):
        view = InputFormView.as_view()
        self.object = self.get_object(queryset=Result.objects.filter(company=company,region=region))            
        return super(Result, self).get(request, *args, **kwargs)

    def get_context_data(self, **kwargs):
        context = super(ResultView, self).get_context_data(**kwargs)
        context['InputFormView']= self.object
        return context


    def get_queryset(self):

<--Error!-- this sentence is where reports error as "global name company,region not defined"-->

        queryset=Result.objects.filter(company=company,region=region)
        sales=Result.objects.queryset.aggregate(Sum('sales'))
        employee=Result.objects.queryset.aggregate(Sum('employee'))
        departments=Result.objects.queryset.aggregate(Sum('departments'))

        return self.object.all()  

您的代碼存在多個問題:

  1. 您的get_queryset方法中有一個if self.request.method == 'POST':塊。 如果該結果為False則您將退回到父get_queryset方法,這將觸發錯誤(因為如錯誤所示,需要為父方法提供模型或查詢集)。 因此,如果您嘗試對result_list/進行簡單的GET請求,則該請求將失敗,因為ListView沒有查詢集。

  2. 您不應該從get_queryset方法內部呈現模板。 該方法應返回一個查詢集,而不會返回其他任何內容。 這將失敗。

  3. 首先,您的ResultView確實不應該處理POST表單數據。 您應該在FormView進行處理,然后使用FormViewsuccess_url參數將用戶重定向到適當的結果視圖,如表單處理文檔中所述。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM