Ошибка Django : NoReverseMatch at /Post/8 Reverse for 'comments' with arguments '('',)' not found

Я работаю над своим проектом и столкнулся с проблемой "COMMENT": Я добавляю комментарий как раздел, когда пользователь нажимает кнопку "просмотр", чтобы увидеть пост с главной страницы.

Ошибка Django : NoReverseMatch at /Post/8 Не найден ответ для 'comments' с аргументами '('',)'. 1 pattern(s) tried: ['Post/(?P[0-9]+)$']

файлviews.py

def viewList(request, id):
item = Post.objects.get(id=id)
context = {
    'item': item,
    'comment_form': comment(),
    'comments': item.get_comments.all(),
}
return render(request, 'auctions/item.html', context)

@login_required
def comments(request, id):
     listing = Post.objects.get(id=id)
     form = comment(request.PSOT)
     newComment = form.save(commit=False)
     newComment.user = request.user
     newComment.listing = listing
     newComment.save()
return HttpResponseRedirect(reverse("listing", {'id': id}))

файл models.py

class Post(models.Model):

# data fields
title = models.CharField(max_length=64)
textarea = models.TextField()

# bid
price = models.FloatField(default=0)
currentBid = models.FloatField(blank=True, null=True)

imageurl = models.CharField(max_length=255, null=True, blank=True)
category = models.ForeignKey(
    Category, on_delete=models.CASCADE, default="No Category Yet!", null=True,  blank=True)

creator = models.ForeignKey(User, on_delete=models.PROTECT)
watchers = models.ManyToManyField(
    User, blank=True, related_name='watched_list')
date = models.DateTimeField(auto_now_add=True)

# for activated the Category
activate = models.BooleanField(default=True)

def __str__(self):
    return f"{self.title} | {self.textarea} |  {self.date.strftime('%B %d %Y')}"

class Comment(models.Model):

body = models.CharField(max_length=100)
createdDate = models.DateTimeField(default=timezone.now)

# link to the post model
auction = models.ForeignKey(
    Post, on_delete=models.CASCADE, related_name="get_comments")

user = models.ForeignKey(User, on_delete=models.CASCADE)

status = models.BooleanField(default=True)

def __str__(self):
    return self.createdDate.strftime('%B %d %Y')

HTML файл

<!-- Comments -->
    <div class="comments">
        <p>Add a comment:</p>
        <div class="row">
            <div class="col-6">
                <form action="{% url 'comments' listing.id %}" method="post">
                    {% csrf_token %}
                    <div class="input-group">
                        {{ comment_form }}
                    </div>
                        <input type="submit" value="save" class="btn btn-outline-dark btn-sm m-1"/>
                </form>
            </div>
        {% for comment in comments %}
            <div class="col-4">
                Comments:
                <h4>Name: {{comment.user}}</h4>
                <h4>Content: {{comment.body}}</h4>
                <h4>Date: {{comment.createdDate}}</h4>
            </div>
        {% endfor %}
        </div>
    </div>

url.py

from django.urls import path 
from . import views


urlpatterns = [
     path("", views.index, name="index"),
     path("login", views.login_view, name="login"),
     path("logout", views.logout_view, name="logout"),
     path("register", views.register, name="register"),
     path("category/", views.category, name="category"),
     path("Post", views.createList, name="createList"),
      #comment url
     path("Post/<str:id>", views.viewList, name="viewList"),
     path("Post/<int:id>", views.comments, name="comments"),
]

Вы передали объект Post как item в шаблон, следовательно, вы должны разрешить URL с:

<!--        use item not listing ↓  -->
<form action="{% url 'comments' item.id %}" method="post">
    …
</form>

Ваш вид для создания комментариев также имеет некоторые ошибки: вы должны использовать request.POST, а не request.PSOT:

from django.shortcuts import redirect

@login_required
def comments(request, id):
    if request.method == 'POST'
         form = comment(request.POST, request.FILES)
         if form.is_valid():
             form.instance.user = request.user
             form.instance.auction_id = id
             form.save()
    return redirect('viewList', id=id)

Кроме того, ваша форма comment должна наследоваться от ModelForm, а не от Form:

class comment(forms.ModelForm):

    class Meta:
        model = Comment
        fields = ('content',)
        widgets = {
            'content': forms.Textarea(attrs={"class": "form-control"})
        }

В итоге ваш urls.py имеет два (полностью) перекрывающихся шаблона, вам следует использовать другой URL для добавления данного комментария:

urlpatterns = [
     # …
     #comment url
     path('Post/<int:id>', views.viewList, name='viewList'),
     path('Post/<int:id>/add', views.comments, name='comments'),
]

Примечание: Обычно Form или ModelForm заканчивается суффиксом …Form, чтобы избежать коллизии с именем модели, и чтобы было ясно, что мы работаем с формой. Поэтому, возможно, лучше использовать CommentForm вместо comment.

Вернуться на верх