0

インスタンスが毎時間作成されるモデルがあります。

class Entry(models.Model):
    class Meta:
        ordering = ['time']

    time = models.DateTimeField()
    no2 = models.FloatField()
    co = models.FloatField()
    humidity = models.FloatField()
    temperature = models.FloatField()

先月の日の平均値を取得したい。たとえば、毎日の平均値を含む 30 のインスタンス。それを実現する方法は?今、私はこのメソッドを書きました:

def average_for_period(self, start, end):
        entries_for_period = Entry.objects.filter(time__gte=start, time__lte=end)
        average_value = entries_for_period.aggregate(Avg('temperature'), Avg('no2'), Avg('co'), Avg('humidity'))
        return Entry(**average_value)

機能を実装するにはどうすればよいですか?

4

2 に答える 2

2

値を返すことを除いて、すべてを正しく行っています。集約されたクエリは Entry インスタンスであってはなりません

avg_values = ['temperature', 'no2', 'co', 'humidity']
average_value = entries_for_period.aggregate(*[Avg(x) for x in avg_values])
return {x:average_value['%s__avg' % x] for x in avg_values}

これは次のようなdictを返します

{'temperature': 202.48803054780439,
 'no2': 4881.734909678366,
 'co': None,
 'humidity': 200}
于 2016-03-26T22:13:31.353 に答える
0

ジョブ スケジューラを介して script.py を定期的に実行することをお勧めします。script.py は、django シェルから離れた django プロジェクトを処理するために、このようにすることができます。

import sys, os

PATH_TO_DJANGO = 'path/to/django/project'
sys.path.append(PATH_TO_DJANGO)
os.environ['DJANGO_SETTINGS_MODULE'] = 'project.settings'

from app import Entry # can be imported after the above config...
import average_for_period # your custom function

# do what you want to ...
于 2016-03-26T12:46:01.473 に答える