0

models.py

class short_url(models.Model):
    """
        This is a short_url class 
    """
    blocked = models.BooleanField(default=False)                                # To check whether URL is blocked or not 
    updated_at = models.DateTimeField(auto_now=True)                            # When URL is updated
    url = models.TextField(validators=[URLValidator()])                         # URL entered by the user
    created_at = models.DateTimeField(auto_now_add=True)                        # When URL is created
    url_hash = models.CharField(max_length=10,unique=True,db_index=True)        # base64 encoded URL id  


class click_info(models.Model):
    """
        This is a click_info class 
    """
    user_ip = models.TextField()                                                # Store the user_ip
    user_agent = models.TextField()                                             # Store the user_agent
    http_refrer = models.TextField()                                            # Store the http_refrer
    hash = models.ForeignKey(short_url)                                         # base64 encoded URL id
    get_parameters = models.TextField()                                         # Store other get_parameters
    request_time = models.DateTimeField()                                       # When user made the request_time
    updated_at = models.DateTimeField(auto_now=True)                            # When click_info is updated
    created_at = models.DateTimeField(auto_now_add=True)                        # When click is created

上記は私の 2 つのモデルです。先週の特定の url_hash の合計クリック数を取得したいと考えています。たとえば、今日クエリを作成すると、過去 1 週間のデータのみが返されるはずです...

Mon:2,Tue:1,Wed:10,Thu:122,Fri:97,Sat:12,Sun:11

4

2 に答える 2

1

先週の週範囲を計算すると、日付範囲クエリを使用できます。例えば。

import datetime
from django.db.models import Count

from_date = datetime.datetime.now() - datetime.timedelta(days=7)

click_info.objects.filter(hash='<value>', created_at__range=[from_date, datetime.datetime.now()])
    .extra({'date_created' : "date(created_at)"})
    .values('date_created')
    .annotate(created_count=Count('id'))

dict 要素のリストが表示されます。目的に応じてさらに操作できます。

[{'date_created': u'2013-09-03', 'created_count': 1}, 
 {'date_created': u'2013-09-04', 'created_count': 1}, 
 {'date_created': u'2013-09-05', 'created_count': 1}, 
 {'date_created': u'2013-09-06', 'created_count': 3}, 
 {'date_created': u'2013-09-07', 'created_count': 1}, 
 {'date_created': u'2013-09-08', 'created_count': 1}, 
 {'date_created': u'2013-09-09', 'created_count': 2}]

以下のスニペットを使用して、日を取り除いて数えることができます。

day_clicks = []
for item in items:
    day = datetime.datetime.strptime(item.get('date_created'), "%Y-%m-%d").date().strftime("%a")
    click_count = item.get('created_count')
    day_clicks.append(day + ':' + str(click_count))
print ", ".join(day_clicks)

結果:

Tue:1, Wed:1, Thu:1, Fri:3, Sat:1, Sun:1, Mon:2
于 2013-09-09T10:50:01.653 に答える