資訊內容
使用Python把圖片存入數據庫
Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
一般情況下我們是把圖片存儲在文件系統中,而只在數據庫中存儲文件路徑的,但是有時候也會有特殊的需求:把圖片二進制存入數據庫。Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
MYSQL是支持把圖片存入數據庫的,也相應的有一個專門的字段BLOB(Binary Large Object),即較大的二進制對象Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
還有個更大的存二進制的LONGBLOB;Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
這里需要注意:盡量把字段設置大一些,因為如果設置的字段長度過小,就會出現圖片只顯示一部分的情況。第二:如果數據量大的話盡量避免使用這種方式進行,因為mysql對于大數據的查詢速度會很慢。Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
1、首先讀取文件,用open()和close()打開和關閉;Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
2、接著用connect()創建數據庫連接;Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
3、用Binary()指定存儲的是二進制;Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
4、然后數據庫提交,關閉數據庫即可。Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
下面是具體的代碼:Iyi少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
#!/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)
- 上一篇
零基礎自學Python要多久才能學會?
簡介零基礎自學Python要多久?學習Python開發的周期因人而異,由于基礎、學習效率不同有的人學習進度快,需要六個月到一年不等,有的人自律性較差可能需要更久的時間才能學會,今天小編分享下6個月學習周期內的自學Python的學習路線。零基礎自學Python學習路線:一、基礎篇安裝python2.7,利
- 下一篇
如何查看mysql日志
簡介MySQL日志主要包含:錯誤日志、查詢日志、慢查詢日志、事務日志、二進制日志。查看日志信息的方法:mysql> show global variables like '%log%';+----------------------