使用python从cx_oracle blob输出图像

时间:2012-01-16 03:14:26

标签: python flask cx-oracle

我已将图像存储在BLOB列中的oracle表中。我用来读取和输出图像并使用JAVA写入数据。我想用python做同样的事情(获取我的图像并分发它)。我正在使用Flask框架和cx_Oracle。

我设法将我的BLOB内容放入我的应用程序中,但我不确定如何从中生成图像。

我知道在 Java 我使用过:

OutputStream out = response.getOutputStream();
response.setContentType(doc.getContentType());
IOUtils.copy( new ByteArrayInputStream(doc.getContent()),out);
out.flush();

其中doc.getContent()是我的BLOB内容。

2 个答案:

答案 0 :(得分:2)

如果您有数据并且只需要将它放到磁盘上的映像文件中,您可以直接将其写入打开的文件以便以二进制模式写入。

import cx_oracle

sql = 'select img_fld from img_table where id=1234'
imagePath = './output/image.png'

conn = cx_oracle.connect('your_connection_string')

cursor = conn.cursor()
cursor.execute(sql)

#assuming one row of image data is returned
row = cursor.fetchone()
imageBlob = row[0]

#open a new file in binary mode
imageFile = open(imagePath,'wb')

#write the data to the file
imageFile.write(imageBlob.read())

#closing the file flushes it to disk
imageFile.close()

cursor.close()
conn.close()

如果您需要"类似文件"如果没有写入磁盘,则可以使用cStringIO模块创建内存缓冲区。 https://docs.python.org/library/stringio.html

答案 1 :(得分:2)

使用Flask和您的帮助:

@app.route('/_photo/')
def gripur():

    conn = cx_Oracle.connect("*****","****",make_dsn_tns(get_config_string()))
    curs = conn.cursor()
    #find photo
    document=curs.execute('select myblob from mytable where id=34234')
    row = cursor.fetchone()
    imageBlob = row[0]

    blob= imageBlob.read()
    response = make_response(blob)
    response.headers["Content-type"] = "image/jpeg"
    conn.close()

    return response