1

djangoビューでは、毎年のコンテンツをフィルターで除外して、テンプレートを介してグラフに表示します。現在、私は各年のマニュアルの計算を行っていますが、年をハードコーディングすることなく、年ごとにコンテンツをフィルタリングするように、コードを修正するためのより良い方法が必要です。また、グラフテンプレートでは、年をハードコーディングしており、ハードコーディングせずに記述できるのではないかと考えていました。

content_count_2006 = ContentItem.objects.filter(timestamp__year=2006).count()
content_count_2007 = ContentItem.objects.filter(timestamp__year=2007).count()
content_count_2008 = ContentItem.objects.filter(timestamp__year=2008).count()
content_count_2009 = ContentItem.objects.filter(timestamp__year=2009).count()
content_count_2010 = ContentItem.objects.filter(timestamp__year=2010).count()
content_count_2011 = ContentItem.objects.filter(timestamp__year=2011).count()

content_per_year = [content_count_2006, content_count_2007, content_count_2008, content_count_2009, content_count_2010, content_count_2011]


{% chart VerticalBarStack content_per_year %}
    {% axes type xy %}
    {% axes label "2006" "2007" "2008" "2009" "2010" "2011" %}
    {% color CCCCCC %}
{% endchart %}
4

1 に答える 1

2

リスト内包表記を使用できます。

content_per_year = [ ContentItem.objects.filter(timestamp__year=y).count() \ 
    for y in range(2006, 2012) ]
于 2011-01-15T15:26:44.867 に答える