In my Django model, I’ve got a very simple model which represents a single occurrence of an event (such as a server alert occurring):
class EventOccurrence:
event = models.ForeignKey(Event)
time = models.DateTimeField()
My end goal is to produce a table or graph that shows how many times an event occurred over the past n weeks.
So my question has two parts:
- How can I
group_bythe week of thetimefield? - How can I “pad out” the result of this
group_byto add a zero-value for any missing weeks?
For example, for the second part, I’d like transform a result like this:
| week | count | | week | count |
| 2 | 3 | | 2 | 3 |
| 3 | 5 | —— becomes —> | 3 | 5 |
| 5 | 1 | | 4 | 0 |
| 5 | 1 |
What’s the best way to do this in Django? General Python solutions are also OK.
Django’s
DateFieldas well asdatetimedoesn’t support week attribute. To fetch everything in one query you need to do: