中文字符不支持Sqlite3到CGI脚本

时间:2012-08-16 03:45:38

标签: python sqlite cgi

通过Cgi脚本将中文字符插入Sqlite3对我来说不起作用。我可以使用查询浏览器工具从同一个数据库中插入和选择中文字符但是当我使用python脚本时,它显示错误。这是我用于创建数据库的查询

CREATE TABLE registrations ( m_username VARCHAR PRIMARY KEY COLLATE 'BINARY', m_identity VARCHAR, m_updatetime DATETIME );

然后这是我用于更新的cgi脚本和从数据库中选择值

#! /Python26/python
dbFile = 'D:/sqlite/registrations'
import cgi
import sqlite3
import xml.sax.saxutils

 query = cgi.parse()
db = sqlite3.connect(dbFile)

user = query.get('username', [None])[0]
identity = query.get('identity', [None])[0]
friends = query.get('friends', [])
print 'Content-type: text/plain\n\n<?xml version="1.0" encoding="utf-8"?>\n'

print "<result>"

if user:
try:
    c = db.cursor()
    c.execute("insert or replace into registrations values (?, ?,      datetime('now'))", (user, identity))
    print "\t<update>true</update>"
except:
    print '\t<update>false</update>'

for f in friends:
print "\t<friend>\n\t\t<user>%s</user>" % (xml.sax.saxutils.escape(f), )
c = db.cursor()
c.execute("select m_username, m_identity from registrations where m_username = ? and m_updatetime > datetime('now', '-1 hour')", (f, ))
for result in c.fetchall():
    eachIdent = result[1]
    if not eachIdent:
        eachIdent = ""
    print "\t\t<identity>%s</identity>" % (xml.sax.saxutils.escape(eachIdent), )
    if f != result[0]:
        print "\t\t<registered>%s</registered>" % (xml.sax.saxutils.escape(result[0]), )
print "\t</friend>"
db.commit()

print "</result>"

我想,我需要将CHARSET设置为UTF-8,但我不知道该怎么做。我用谷歌搜索,但找不到解决这个问题的好方法。请有人帮助我。

1 个答案:

答案 0 :(得分:0)

我是通过客户端完成的。我刚刚使用了EncodeBase64并编码了中文数据并发送到数据库。我想,这个不是直截了当的方式。但我找不到任何其他方式。