我如何用Python在ut8mb4中编码一些东西?
我有两组数据:从Parse迁移到我的新MySQL数据库的数据,以及未来的数据(这只涉及到我的新数据库)。我的数据库是utf8mb4,用来存储表情符号和重音字母。
当我有python脚本时,第一组数据才会正确显示(涉及表情符号和口音):
MySQLdb.escape_string(unicode(xstr(data.get('message'))).encode('utf-8')) 在用PHP读取MySQL数据库时:
$row["message"] = utf8_encode($row["message"]);当我不包括utf8_encode($row["message"])部分时,第二组数据才会正确显示(涉及表情符号和口音)。我试图调和这些数据,以便将这两组数据正确地返回到我的iOS应用程序中。请帮帮我!
发布于 2014-12-09 22:23:59
为了Emoji和U+FFFF代码点以外的其他字符,我一直在努力在Python和U+FFFF之间正确地交换UTF-8字符。
为了确保一切顺利,我必须做以下工作:
utf8mb4用于CHAR、VARCHAR和MySQL中的TEXT列要在Python中强制执行UTF-8,请添加以下行作为Python脚本的第一行或第二行:
# -*- coding: utf-8 -*-要在Python之间强制执行UTF-8,请按以下方式设置MySQL连接:
# Connect to mysql.
dbc = MySQLdb.connect(host='###', user='###', passwd='###', db='###', use_unicode=True)
# Create a cursor.
cursor = dbc.cursor()
# Enforce UTF-8 for the connection.
cursor.execute('SET NAMES utf8mb4')
cursor.execute("SET CHARACTER SET utf8mb4")
cursor.execute("SET character_set_connection=utf8mb4")
# Do database stuff.
# Commit data.
dbc.commit()
# Close cursor and connection.
cursor.close()
dbc.close()这样,您就不需要使用像encode和utf8_encode这样的函数。
发布于 2016-12-18 04:23:04
use_unicode=True不是为我工作的。
我的解决方案
MySQLdb.connect(host='###' [...], charset='utf8'dbCursor.execute('SET NAMES utf8mb4')dbCursor.execute("SET CHARACTER SET utf8mb4")发布于 2019-09-23 11:35:31
还可以按以下方式输入所需代码的类型
mysql.connector.connect(host = '<host>', database = '<db>', user = '<user>', password = '<password>', charset = 'utf8')“<>”中的字段是您自己的详细信息。与“utf8”不同,您还可以根据mysqldb需要的编码类型编写“utf8mb4”。
https://stackoverflow.com/questions/26532722
复制相似问题