Django - ошибка NoReverseMatch даже при правильных параметрах (без интервалов между именами)
Я пытаюсь создать приложение, которое хранит задачи (в частности, математические задачи) и отображает их пользователю. Я еще не добавил большую часть функциональности, которую хочу, и поскольку я довольно новичок в Django, я следовал проекту Django Tutorial и изменял его в соответствии с моими потребностями. Однако, я сталкиваюсь с ошибкой NoReverseMatch, несмотря на то, что я передаю правильные параметры. Мой код приведен ниже.
models.py
import imp
from django.db import models
from django.urls import reverse
import uuid
# Create your models here.
class Source(models.Model):
'''Model that represents the source of a problem (e.g. AMC, AIME, etc.)'''
problem_source = models.CharField(max_length=20)
problem_number = models.PositiveSmallIntegerField()
def __str__(self):
'''toString() method'''
return f'{self.problem_source} #{self.problem_number}'
class Topic(models.Model):
'''Model that represents the topic of a problem (e.g. Intermediate Combo)'''
problem_topic = models.CharField(max_length=50)
problem_level = models.CharField(max_length=15)
def __str__(self):
return f'{self.problem_level} {self.problem_topic}'
class Problem(models.Model):
'''Model that represents each problem (e.g. AIME #1, AMC #11, etc.)'''
id = models.UUIDField(primary_key=True, default=uuid.uuid4)
source = models.OneToOneField(Source, on_delete=models.RESTRICT, null=True, unique=True)
problem_text = models.TextField()
topic = models.ManyToManyField(Topic)
def __str__(self):
"""String for representing the Model object."""
return f'{self.source}'
def get_absolute_url(self):
"""Returns the url to access a detail record for this book."""
return reverse('problem-detail', args=[str(self.id)])
urls.py
from django.urls import path
from . import views
urlpatterns = [
path('', views.index, name='index'),
path('problems/', views.ProblemListView.as_view(), name='problems'),
path('problem/<int:pk>', views.ProblemListView.as_view(), name='problem-detail'),
]
views.py
import imp
from django.shortcuts import render
# Create your views here.
from .models import Problem, Source, Topic
def index(request):
'''View function for home page of site'''
# generate counts of the main objects
num_problems = Problem.objects.all().count()
context = {
'num_problems': num_problems,
}
return render(request, 'index.html', context=context)
from django.views import generic
class ProblemListView(generic.ListView):
model = Problem
class ProblemDetailView(generic.DetailView):
model = Problem
Ссылки на мои HTML файлы приведены ниже:
base_generic.html: ссылка
problem_list.html: ссылка
problem_detail.html: link
Мое рабочее пространство структурировано следующим образом:
trivial
catalog
migrations
static/css
styles.css
templates
catalog
problem_detail.html
problem_list.html
base_generic.html
index.html
__init.py
admin.py
apps.py
models.py
tests.py
urls.py
views.py
trivial
__init__.py
asgi.py
settings.py
urls.py
wsgi.py
db.sqlite3
manage.py
Я прочитал другие сообщения StackOverflow, но ни одно из них, похоже, не применимо к моей ситуации. Кроме того, в problem_list.html, если значение в ссылке href равно Problem.get_absolute_url, сайт загрузится, но щелчок по ссылке "все проблемы" приведет обратно на ту же страницу. Но если я помещу prob.get_absolute_url в ссылку href, то получу ошибку NoReverseMatch.
Вот точная ошибка, которую я получаю:
NoReverseMatch at /catalog/problems/
Reverse for 'problem-detail' with arguments '('41b936f7-3c08-4fb9-a090-2d466348d34d',)' not found. 1 pattern(s) tried: ['catalog/problem/(?P<pk>[0-9]+)\\Z']
Request Method: GET
Request URL: http://127.0.0.1:8000/catalog/problems/
Django Version: 4.0.2
Exception Type: NoReverseMatch
Exception Value:
Reverse for 'problem-detail' with arguments '('41b936f7-3c08-4fb9-a090-2d466348d34d',)' not found. 1 pattern(s) tried: ['catalog/problem/(?P<pk>[0-9]+)\\Z']
Django говорит мне, что ошибка связана с вызовом prob.get_absolute_url в problem_list.html
Проблема в том, что ваш id в модели Problem является UUID, но ваш шаблон URL ожидает целочисленное значение в качестве pk - потому что вы приписали к именованному шаблону int::
path('problem/<int:pk>', views.ProblemListView.as_view(), name='problem-detail'),
Он должен работать, если вы измените его на:
path('problem/<str:pk>', views.ProblemListView.as_view(), name='problem-detail'),