5

sqlite3 データベースからレコードを読み込んでいます。データはデータベースに TEXT として保存されますが、バッファーを取得しています (これは Unicode であり、それらを使用可能なテキスト (Unicode かどうか) に変換するように見えるものは何もありません)

それを機能させるには、SQL クエリで 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 の前の「キャッシュ レコード」の文字間のスペースはヌルです。

ありがとう。

4

2 に答える 2

5

試す:

print str(row[0]).decode('utf-16le')
于 2012-09-27T19:13:13.593 に答える
0

"Internet Explorer History"テーブルにデータを挿入する方法 私の推測では、それはバイナリ オブジェクト (Python 型バッファなど) として挿入されているので、SQLite はそれをテキストではなく blob として返します。

適切な Unicode オブジェクトを挿入してから、同じクエリを実行し、その出力を確認してください。

于 2014-07-14T15:27:34.903 に答える