#python #html #django #django-models #django-views
#python #HTML #django #django-модели #django-просмотры
Вопрос:
Я получаю сообщение об ошибке после того, как я добавил модель обзора в django … на странице администратора создается модель, но на моем сайте она не работает.Я не знаю, где я ошибаюсь…пожалуйста, направьте меня
Получение ошибки в строке 28 из base.html
Он также показывает ошибку при views.py строка 21
views.py
from django.shortcuts import render, redirect
from django.http import HttpResponse
from .models import *
from .forms import *
# Create your views here.
def home(request):
allbooks= book.objects.all()
context= {
"books": allbooks,
}
return render(request,'main/index.html',context) #error line
def detail (request,id):
bk=book.objects.filter(id=id)
reviews=Review.objects.filter(book=id)
context ={
"book":bk,
"reviews":reviews
}
return render (request,'main/details.html',context)
def addBooks(request):
if request.user.is_authenticated:
if request.user.is_superuser:
if request.method== "POST":
form=BookForm (request.POST or None)
if form.is_valid():
data=form.save(commit=False)
data.save()
return redirect("main:home")
else:
form=BookForm()
return render (request, 'main/addbooks.html',{"form":form,"controller":"Add Books"})
else:
return redirect("main:home")
else:
return redirect("accounts:login")
def editBooks(request,id):
if request.user.is_authenticated:
if request.user.is_superuser:
bk=book.objects.get(id=id)
if request.method== "POST":
form=BookForm (request.POST or None,instance=bk)
if form.is_valid():
data=form.save(commit=False)
data.save()
return redirect("main:detail",id)
else:
form=BookForm(instance=bk)
return render (request, 'main/addbooks.html',{"form":form,"controller":"Edit Books"})
else:
return redirect("main:home")
else:
return redirect("accounts:login")
def deleteBooks(request,id):
if request.user.is_authenticated:
if request.user.is_superuser:
bk=book.objects.get(id=id)
bk.delete()
return redirect("main:home")
else:
return redirect("main:home")
else:
return redirect("accounts:login")
def add_review(request,id):
if request.user.is_authenticated:
bk=book.objects.get(id=id)
if request.method == "POST":
form= ReviewForm(request.POST or None)
if form.is_valid():
data=form.save(commit=False)
data.comment=request.POST["comment"]
data.rating=request.POST["rating"]
data.user=request.user
data.book=bk
data.save()
return redirect("main:detail",id)
else:
form=ReviewForm()
return render(request,'main/details.html',{"form":form})
else:
return redirect("accounts:login")
base.html
<div class="collapse navbar-collapse" id="navbarSupportedContent">
<ul class="navbar-nav mr-auto">
<li class="nav-item active">
<a class="nav-link" href="{%url 'main:home'%}">Home<span class="sr-only">(current)</span></a> <!--error line-->
</li>
{% if request.user.is_authenticated %}
{% if request.user.is_superuser %}
<li class="nav-item">
<a class="nav-link" href="{% url 'main:add_books'%}">Add Books</a>
</li>
{% endif %}
{% endif %}
details.html
<div class="card">
<div class="card-body">
<h3 class="text-center">Reviews</h3>
<form action="{%url 'main:add_review' book.id%}"method="POST">
{% csrf_token %}
<label for="comment">Review</label>
<textarea name="comment" id="comment" cols="30" rows="5" class="form-control"></textarea>
<label for="rating">Rating</label>
<input type="text" name="rating" class="form-control">
<br>
<input type="submit" class="btn btn-danger" value="Add Review">
</form>
</div>
</div>
<div class="card">
<div class="card-body">
<ul>
{% for review in reviews %}
<li>{{review.comment}} <i>{{review.user}}</i></li>
{% endfor %}
</ul>
</div>
</div>
models.py
class Review(models.Model):
book=models.ForeignKey(book,on_delete=models.CASCADE)
user=models.ForeignKey(User,on_delete=models.CASCADE)
comment=models.TextField(max_length=10000)
rating=models.FloatField(default=0)
def __str__(self):
return self.user.username
Комментарии:
1. В Python и Django вы обычно называете модель
Book
и используетеbook
для отдельногоbook
пользователя . Я рекомендую вам переименовать модель вBook
, потомуbook.objects.all()
что это выглядит запутанным для других пользователей Django.
Ответ №1:
Проблема здесь:
def detail(request,id):
bk=book.objects.filter(id=id)
filter()
вернет набор запросов книг. Вы хотите получить фактическую книгу, поэтому используйте get()
вместо этого:
def detail(request,id):
bk=book.objects.get(id=id)
Это должно устранить ошибку, но вы получите BookDoesNotExist
исключение, если книга с таким идентификатором не существует в базе данных. Вы можете использовать get_object_or_404
для обработки этого:
from django.shortcuts import get_object_or_404
def detail(request,id):
bk=get_object_or_404(book, id=id)
...