我应该在我的flask sqlite数据库中使用什么数据类型的图像?

时间:2013-12-05 04:17:52

标签: 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

所以,这个问题是我有这个列,图像,这将是一个实际的图片,但我不知道在烧瓶代码中使用什么数据类型。

这是烧瓶代码: 的烧瓶

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}

查看我将reqparse的{​​{1}}类型设置为image的位置?这甚至不是一个实际的数据类型,但我不知道该放在那里。我是否需要继承blob?有任何想法吗?感谢


新的问题方法

根据一些评论,似乎我应该将图像存储在我的静态文件夹中。我能做到。但是,我如何用我的数据库引用它?它是一个与fields.Raw文件对应的字符串吗?

2 个答案:

答案 0 :(得分:5)

parser.add_argument('picture',type = werkzeug.datastructures.FileStorage,location ='files')

答案 1 :(得分:4)

除此之外,通常还需要从浏览器上传这样的图像。

出于这个原因,我使用Flask-Uploads来处理上传和投放时的所有存储和命名问题。

以下是有关如何使用它的文档的示例:

photos = UploadSet('photos', IMAGES)

@app.route('/upload', methods=['GET', 'POST'])
def upload():
    if request.method == 'POST' and 'photo' in request.files:
        filename = photos.save(request.files['photo'])
        rec = Photo(filename=filename, user=g.user.id)
        rec.store()
        flash("Photo saved.")
        return redirect(url_for('show', id=rec.id))
    return render_template('upload.html')

@app.route('/photo/<id>')
def show(id):
    photo = Photo.load(id)
    if photo is None:
        abort(404)
    url = photos.url(photo.filename)
    return render_template('show.html', url=url, photo=photo)

使用.save()方法将传入文件存储在目录中。 Flask-Uploads会返回保存的文件名。稍后,使用.url()或.path()来获取对已保存文件的引用。