我正在读取sqlite3数据库中的记录。 数据作为TEXT存储在数据库中,但是我得到了缓冲区(使用Unicode并且我找不到任何东西似乎将它们转换为可用的文本(Unicode或不是))
为了使其工作,我必须在SQL查询中CAST到TEXT。
我错过了什么?
举个例子:
import sqlite3
con = sqlite3.connect('D:\\test.db' )
cur = con.cursor()
print "Before CAST"
cur.execute('SELECT Type FROM \"Internet Explorer History\" ')
row = cur.fetchone()
print row
print row[0]
print type(row[0])
print str(row[0])
print str(row[0]).encode('utf-8')
print "----------------"
print "After CAST"
cur.execute('SELECT CAST( Type as TEXT) FROM \"Internet Explorer History\" ')
row = cur.fetchone()
print row
print row[0]
print type(row[0])
print str(row[0])
print str(row[0]).encode('utf-8')
这给出了以下输出:
Before CAST
(<read-write buffer ptr 0x0276A890, size 24 at 0x0276A870>,)
C a c h e R e c o r d
<type 'buffer'>
C a c h e R e c o r d
C a c h e R e c o r d
----------------
After CAST
(u'Cache Record',)
Cache Record
<type 'unicode'>
Cache Record
Cache Record
注意:CAST之前的“缓存记录”字母之间的空格为空。
感谢。
答案 0 :(得分:5)
尝试:
print str(row[0]).decode('utf-16le')
答案 1 :(得分:0)
如何将数据插入"Internet Explorer History"
表格?我敢打赌它是作为二进制对象(例如Python类型缓冲区)插入的,因此SQLite将其作为blob而不是文本返回。
尝试插入正确的unicode对象,然后执行相同的查询并检查其输出。