因此,我试图添加保存在指定目录中的图像名称,但是此错误不断出现,并且在数据库中未添加任何内容,尽管图像一直保存在指定目录中。 这是我所有的文件 Models.py
from shop import db
from datetime import datetime
class Product(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(80), nullable=False)
price = db.Column(db.Numeric(10,2), nullable=False)
stock = db.Column(db.Integer, nullable=False)
desc = db.Column(db.Text, nullable=False)
pub_date = db.Column(db.DateTime, nullable=False,
default=datetime.utcnow)
brand_id = db.Column(db.Integer, db.ForeignKey('brand.id'),
nullable=False)
brand = db.relationship('Brand',
backref=db.backref('brands', lazy=True))
category_id = db.Column(db.Integer, db.ForeignKey('category.id'),
nullable=False)
category = db.relationship('Category',
backref=db.backref('categories', lazy=True))
image_1 = db.Column(db.String(256), nullable=False, default='image1.jpg')
image_2 = db.Column(db.String(256), nullable=False, default='image2.jpg')
image_3 = db.Column(db.String(256), nullable=False, default='image3.jpg')
def __repr__(self):
return '<Product %r>' % self.name
class Brand(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(64), nullable=False, unique=True)
class Category(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(64), nullable=False, unique=True)
db.create_all()
forms.py
from flask_wtf.file import FileAllowed, FileField, FileRequired
from wtforms import Form,StringField, IntegerField, BooleanField, TextAreaField, validators
class AddProducts(Form):
name = StringField("Name", [validators.DataRequired()])
price = IntegerField("Price:RS ", [validators.DataRequired()])
stock = IntegerField("Stock", [validators.DataRequired()])
desc = TextAreaField("Description", [validators.DataRequired()])
# colors = TextAreaField("Colors", [validators.DataRequired()])
image_1 = FileField('Image 1', [FileRequired(), FileAllowed(['jpg, jpeg, png, svg, gif']), "Images Only please"])
image_2 = FileField('Image 2', [FileRequired(), FileAllowed(['jpg, jpeg, png, svg, gif']), "Images Only please"])
image_3 = FileField('Image 3', [FileRequired(), FileAllowed(['jpg, jpeg, png, svg, gif']), "Images Only please"])
* routes.py
@app.route('/addproduct', methods=["GET", "POST"])
def addproduct():
brands = Brand.query.all()
categories = Category.query.all()
form = AddProducts(request.form)
if request.method == "POST":
name = form.name.data
price = form.price.data
stock = form.stock.data
desc = form.desc.data
brand = request.form.get('brand')
category = request.form.get('category')
image_1 = photos.save(request.files['image_1'] , name=secrets.token_hex(10) + '.')
image_2 = photos.save(request.files['image_2'] , name=secrets.token_hex(10) + '.')
image_3 = photos.save(request.files['image_3'] , name=secrets.token_hex(10) + '.')
print(f"Image 1 name:{image_1}, its type:{type(image_1)}")
product = Product(name=name, price=price, stock=stock, desc=desc, brand=brand, category=category,
image_1=image_1,image_2=image_2, image_3=image_3)
db.session.add(product)
flash(f"{name} has been added to database.", 'success')
db.session.commit()
return redirect(url_for('admin'))
return render_template('products/addproduct.html', title='Add Product', form=form, brands=brands,
categories=categories)
所有图像类型都是字符串,而模型字段也是字符串,但我仍然不断收到此错误。 这是此表单的html页面
{% extends 'layout.html' %}
{% block body_block %}
{% include '_messages.html' %}
<div class="container">
<div class="row">
<div class="col-md-2"></div>
<div class="col-md-8">
<h2 class="text-center bg-info p-2">
Add product
</h2>
{% from '_formhelpers.html' import render_field %}
<form action="" method="POST" enctype="multipart/form-data">
{{ render_field(form.name, class="form-control", placeholder="Product Name")}}
{{ render_field(form.price, class="form-control", placeholder="Price") }}
{{ render_field(form.stock, class="form-control", placeholder="Stock") }}
<label for="brand">Add a Brand</label>
<select class="form-control" name="brand" id="brand">
<option value="" class="form-control" required> Select a Brand</option>
{% for brand in brands%}
<option value="brand.id" class="form-control">{{brand.name}}</option>
{% endfor %}
</select>
<label for="category">Add a Category</label>
<select class="form-control" name="category" id="category">
<option value="" class="form-control" required> Select a Category</option>
{% for category in categories %}
<option value="category.id" class="form-control">{{category.name}}</option>
{% endfor %}
</select>
{{ render_field(form.desc, class="form-control", placeholder="Product Description", rows=10) }}
<div class="container">
<div class="row">
<div class="col-md-4">
{{ render_field(form.image_1, class="form-control")}}
</div>
<div class="col-md-4">
{{ render_field(form.image_2, class="form-control")}}
</div>
<div class="col-md-4">
{{ render_field(form.image_3, class="form-control")}}
</div>
</div>
</div>
<button type="submit" class="btn btn-outline-info mt-4">Add Product</button>
</form>
</div>
<div class="col-md-2"></div>
</div>
</div>
{% endblock body_block %}
答案 0 :(得分:0)
我在下面简化了您的示例。错误发生在第五行:
image_1 = photos.save()
image_2 = photos.save()
image_3 = photos.save()
print(f"Image 1 name:{image_1}, its type:{type(image_1)}")
product = Product(brand=brand, category=category) # <- HERE
db.session.add(product)
由于您提到它将图像保存到目录中,因此表示前3行成功。而且没有任何内容添加到数据库,表明该错误在第4行和第6行之间。
由于您在models.py
中指定了属性brand
和category
是关系属性(db.relationship()
),因此这些属性需要一个ORM对象,向他们传递一个字符串。
实例化ORM对象,然后将其传递给Product
,如下所示:
brand = Brand(name="brandname")
category = Category(name="categoryname")
product = Product(brand=brand, category=category)
这是此答案中指出的内容,可以理解,这是一本很长的文章:https://stackoverflow.com/a/55877355/3407256