Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python SQLite返回无法转换为可用字符串的Unicode缓冲区_Python_Sqlite - Fatal编程技术网

Python SQLite返回无法转换为可用字符串的Unicode缓冲区

Python SQLite返回无法转换为可用字符串的Unicode缓冲区,python,sqlite,Python,Sqlite,我正在从sqlite3数据库中读取记录。 数据以文本形式存储在数据库中,但是我得到的缓冲区是Unicode格式的,我找不到任何东西可以将它们转换为可用的文本Unicode或非Unicode格式 要使其工作,我必须转换为SQL查询中的文本 我错过了什么 例如: import sqlite3 con = sqlite3.connect('D:\\test.db' ) cur = con.cursor() print "Before CAST" cur.execute('SELECT Type

我正在从sqlite3数据库中读取记录。 数据以文本形式存储在数据库中,但是我得到的缓冲区是Unicode格式的,我找不到任何东西可以将它们转换为可用的文本Unicode或非Unicode格式

要使其工作,我必须转换为SQL查询中的文本

我错过了什么

例如:

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
注意:强制转换前“缓存记录”的字母之间的空格为空

谢谢。

试试:

print str(row[0]).decode('utf-16le')

如何将数据插入Internet Explorer历史记录表?我打赌它是作为二进制对象插入的,例如Python类型的缓冲区,所以SQLite将它作为blob而不是文本返回


尝试插入正确的unicode对象,然后执行相同的查询并检查其输出。

您是否使用SQLite命令行工具尝试了此操作?结果是什么?它返回正确的字符串“Cache Record”(带强制转换和不带强制转换)?如果打印bytesrow[0]和/或reprrow[0]或[ordc for c in row[0]],请显示Internet Explorer历史记录中选择的类型quoteType的输出。@cymro,我对sqlite不太熟悉,但文档中说它根据数据库设置以相同的格式存储所有文本。显然,您的数据库是为utf-16le设置的。通过将其转换为文本,SQL驱动程序可能为您完成了转换。看见