ホームページ  >  記事  >  バックエンド開発  >  Pythonを使用して画像をデータベースに保存する

Pythonを使用して画像をデータベースに保存する

高洛峰
高洛峰オリジナル
2016-10-18 10:36:301916ブラウズ

通常、画像はファイル システムに保存され、データベースにはファイル パスのみが保存されますが、画像バイナリをデータベースに保存するという特別なニーズが発生する場合があります。

今日は Python+mysql メソッドを使用します

MYSQL はデータベースへの画像の保存をサポートしており、それに応じて、より大きなバイナリ オブジェクトである特別なフィールド BLOB (Binary Large Object) があります

より大きなバイナリ LONGBLOB もあります

ここで注意してください: フィールドの長さが小さすぎると、画像の一部しか表示されないため、フィールドをできるだけ大きく設定するようにしてください。 2 番目: データの量が多い場合は、mysql がビッグデータをクエリするのに非常に時間がかかるため、この方法の使用は避けてください。

以下のコード:

#!/usr/bin/python
#-*- coding: UTF-8 -*-
  
import MySQLdb as mysql
import sys
try:
    #读取图片文件
    fp = open("./test.jpg")
    img = fp.read()
    fp.close()
except IOError,e:
    print "Error %d %s" % (e.args[0],e.args[1])
    sys.exit(1)
try:
    #mysql连接
    conn = mysql.connect(host='localhost',user='root',passwd='123456',db='test')
    cursor = conn.cursor()
    #注意使用Binary()函数来指定存储的是二进制
    cursor.execute("INSERT INTO images SET data='%s'" % mysql.Binary(img))
    #如果数据库没有设置自动提交,这里要提交一下
    conn.commit()
    cursor.close()
    #关闭数据库连接
    conn.close()
except mysql.Error,e:
    print "Error %d %s" % (e.args[0],e.args[1])
    sys.exit(1)


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。