date_based object_detail дает 404 в django - PullRequest
0 голосов
/ 27 февраля 2011

Я пытаюсь использовать постоянные ссылки в Django, используя довольно стандартную модель / / / / / . Тем не менее, я получаю 404 без дополнительной информации

urls.py включает в себя races.urls, используя

    (r'^races/', include('races.urls')),

Мои расы / urls.py выглядят следующим образом:

from django.conf.urls.defaults import *
from django.views.generic import date_based
from races.models import Race

info_dict = { 
    'date_field': 'date',
    'month_format': '%m',
    'queryset': Race.objects.all,
    'year': 'year',
    'month': 'month',
    'day': 'day',
}

urlpatterns = patterns('',
    (r'^$', 'races.views.index'),
    (r'^(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d{2})$', 
        date_based.archive_day, dict(info_dict)),
    url(r'^(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d{2})/(?P<slug>[-\w]+)', 
        date_based.object_detail, 
        dict(info_dict, slug_field='slug', slug='slug', 
            template_name='races/race_detail.html'), 
        name = 'race_detail'),
)

Мои расы / models.py имеют

from django.db import models
from django.template.defaultfilters import slugify

class Race(models.Model):
    STATUS_CHOICES = (
        ('Completed', 'Completed'),
        ('Entered', 'Entered'),
        ('Planned', 'Planned'),
        ('DNS', 'DNS'),
        ('DNF', 'DNF'),
    )
    name = models.CharField(max_length=100)
    date = models.DateField('race date')
    time = models.TimeField('race duration', null = True)
    status = models.CharField(max_length=10, choices = STATUS_CHOICES) 
    slug = models.SlugField(max_length=100, editable = False)

    def save(self, *args, **kwargs):
        if not self.id:
            self.slug = slugify(self.name)
        super(Race, self).save(*args, **kwargs)

    def __unicode__(self): 
        return self.name 

    @models.permalink
    def get_absolute_url(self):
        return('race_detail', (), { 
            'year': self.date.year,
            'month': self.date.month,
            'day': self.date.day, 
            'slug': self.slug })

Тестовая гонка определенно появляется в БД

mysql> select * from races_race;
+----+---------------------+------------+----------+-----------+---------------------+
| id | name                | date       | time     | status    | slug                |
+----+---------------------+------------+----------+-----------+---------------------+
|  1 | Race Your Pace Half | 2011-02-20 | 01:41:15 | Completed | race-your-pace-half |
+----+---------------------+------------+----------+-----------+---------------------+

Но URL http://localhost:8000/races/2011/02/20/race-your-pace-half не работает.

Я уверен, что это что-то довольно очевидное, потребовалось время, чтобы заставить работать вышеперечисленное.

С другой стороны, постоянные ссылки также не работают - т. Е. {{Race.get_absolute_url}} отображается пустым в моих шаблонах, я просто не знаю, неверна ли моя модель или URLconf.

1 Ответ

0 голосов
/ 27 февраля 2011

Я никогда не использовал универсальное представление, но безошибочное 404, я думаю, происходит отсюда:

try:
    tt = time.strptime('%s-%s-%s' % (year, month, day),
                       '%s-%s-%s' % ('%Y', month_format, day_format))
    date = datetime.date(*tt[:3])
except ValueError:
    raise Http404

Интересно, переопределяет ли ваш info_dict какой-либо "реальный" ввод, потому что яобратите внимание, что вы передаете строковые аргументы для каждого из обязательных полей ('day': 'day')

Удалите 'day', 'year', and 'month' в качестве аргументов в info_dict, поскольку ваш URL уже захватывает и отправляет эти аргументы.

После этого я хотел бы знать, получите ли вы AttributeError, потому что Race.objects.all - это функция, а не QuerySet.

Дайте мне знать, как это получается!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...