Django:从表单示例保存到数据库

Law*_*nez 6 python django django-forms

看来我很难找到有关从表单将数据保存到DB的好的资源/教程。随着它的发展,我正在慢慢地迷路。我是Django的新手,请指导我。我遇到错误

分配前引用的本地变量“商店”

这是我的相关代码,

models.py

from django.db import models

# Create your models here.
class Store(models.Model):
    store_name = models.CharField(max_length=100)

    def __unicode__(self):
        return self.store_name

class Feedback(models.Model):
    store = models.ForeignKey(Store)
    username = models.CharField(max_length=100)
    comment = models.CharField(max_length=1000)
    date = models.DateTimeField("comment_date")

    def __unicode__(self):
        return self.username
Run Code Online (Sandbox Code Playgroud)

views.py

def add(request, store_name):
    if request.method == "POST":
        store = Store.objects.get(store_name=store_name)
        saved_username = request.POST.get("username", "")
        saved_feedback = request.POST.get("feedback", "")
        feedback = Feedback(username=saved_username, comment=saved_feedback, date=timezone.now())
        feedback.save()
    return HttpResponseRedirect(reverse("view", args=(store.id,)))
Run Code Online (Sandbox Code Playgroud)

addfeedback.html(调用该代码的人将views.py添加)

<html>
<head><title>Add Feedback</title>
<link rel="stylesheet" type="text/css" href={{ STATIC_URL }}styles.css>
</head>

<body>
    <div class="form">
    <form action="{% url add store.store_name %}" method="post">
    {% csrf_token %}
        <input type="text" name="username" size="20"><br />
        <textarea name="feedback" cols="50" rows="10"></textarea><br />
        <input type="submit" value="Add" />
    </form>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

Krz*_*arz 2

用于django.forms工作。不要直接将数据放入POST数据库。请参阅相关文档

\n\n
local variable \'store\' referenced before assignment\n
Run Code Online (Sandbox Code Playgroud)\n\n

store即使请求不是 ,您正在引用的错误也很明显 \xe2\x80\x93 POST

\n