2

我开始使用 Django,虽然我已经阅读了这本书并用谷歌搜索,但我担心我没有在某些概念上建立联系以解决这个问题。

我需要显示与特定公司相对应的几个值。用户首先选择三个公司进行比较,然后响应显示这些公司的数据。

在我看来,我创建了在模板中迭代的查询集,以显示数据,如下所示:

观点摘录:

        C1 = form.cleaned_data['Company1']
        C2 = form.cleaned_data['Company2']
        C3 = form.cleaned_data['Company3']

        company_names = [C1,C2,C3]

        company1 = (Company_stats.objects.filter(period__exact=P, company_name__exact=C1))
        company2 = (Company_stats.objects.filter(period__exact=P, company_name__exact=C2))
        company3 = (Company_stats.objects.filter(period__exact=P, company_name__exact=C3))

        company_list = [company1,company2,company3]

模板摘录:

  {%for c in company_list%}    
     {%for z in c %}
        {{ z.company_name }}
        {{ z.nxt_m_ret_est }}    
        {{ z.nxt_m_ret_rat }}
     {% endfor %}  
  {% endfor %}

这行得通 - 但是,因为我有更多的移动部件(为了我的问题,我已经简化了视图)它变成了一个无穷无尽的查询集洗衣清单 - 我 100% 确定这不是 DRY(尽管有洗衣参考 ;) 更不用说上下文的长度了。

如果有人可以帮助我学习以正确的方式做到这一点,我将不胜感激。非常感谢您!

4

2 回答 2

1

试试这个:

companies = ['Company1', 'Company2', 'Company3']

company_names = [form.cleaned_data[c] for c in companies]

company_list = Company_stats.objects.filter(
    period__exact=P, 
    company_name__in=company_names
)

即使这不完全符合您的需要,类似的东西也应该起作用。

于 2012-12-04T18:00:27.830 回答
0

我还要补充一点,千篇一律的查询是经理真正发光的地方。如果您发现也需要在代码的其他地方进行相同的查询,请绝对考虑使用它们。我暂时避开了它们,因为我认为它们很复杂,但它们真的不是那么糟糕,它们可以相当多地清理你的代码。

于 2012-12-04T18:58:28.840 回答