Ale*_*ley 4 python sqlite types flask-extensions
所以我在Flask的sqlite数据库中有这个db.model。看起来像这样:
class Drink(db.Model):
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.String(64), index = True)
kind = db.Column(db.String(64), index = True)
image = db.Column(db.LargeBinary)
def __init__(self, name, kind, image):
self.name = name
self.kind = kind
self.image = image
def __repr__(self):
return '<Drink %r>' % self.name
Run Code Online (Sandbox Code Playgroud)
所以,这个问题是我有此列image,这是一张实际的图片,但是我不知道在烧瓶代码中使用哪种数据类型。
这是烧瓶代码: Flask
class DrinkAPI(Resource):
def __init__(self):
self.reqparse = reqparse.RequestParser()
self.reqparse.add_argument('name', type = str, required = True, help = 'No name title provided', location = 'json')
self.reqparse.add_argument('type', type = str, required = True, help='No type provided', location = 'json')
self.reqparse.add_argument('image', type = blob, required = True, help='No image provided', location = 'json')
super(DrinkAPI, self).__init__()
def get(self, id):
if checkDrink(id):
info = getDrinkInfo(id)
return {'id': id, 'name': info[0], 'type':info[1], 'image': info[2]}
abort(404)
def put(self, id):
if checkDrink(id):
args = self.reqparse.parse_args()
deleteDrink(id)
drink = Drink(args['name'], args['type'], args['image'])
addDrink(drink)
return {'drink' : marshal(drink, drink_fields)}, 201
abort(404)
def delete(self, id):
deleteDrink(id)
return { 'result': True}
Run Code Online (Sandbox Code Playgroud)
看到我把我的类型reqparse
的image
到blob
?那甚至不是实际的数据类型,但是我不知道该放在哪里。我需要子类化fields.Raw
吗?有任何想法吗?谢谢
问题的新方法
根据一些评论,看来我应该将图像存储在我的静态文件夹中。我可以的 但是,如何在我的数据库中引用它呢?它是与.jpg
文件相对应的字符串吗?
parser.add_argument('picture',type = werkzeug.datastructures.FileStorage,location ='files')
归档时间: |
|
查看次数: |
5669 次 |
最近记录: |