首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Python中编码(utf8mb4)

如何在Python中编码(utf8mb4)
EN

Stack Overflow用户
提问于 2014-10-23 16:22:34
回答 3查看 27.3K关注 0票数 13

我如何用Python在ut8mb4中编码一些东西?

我有两组数据:从Parse迁移到我的新MySQL数据库的数据,以及未来的数据(这只涉及到我的新数据库)。我的数据库是utf8mb4,用来存储表情符号和重音字母。

当我有python脚本时,第一组数据才会正确显示(涉及表情符号和口音):

代码语言:javascript
复制
MySQLdb.escape_string(unicode(xstr(data.get('message'))).encode('utf-8')) 

在用PHP读取MySQL数据库时:

代码语言:javascript
复制
$row["message"] = utf8_encode($row["message"]);

当我不包括utf8_encode($row["message"])部分时,第二组数据才会正确显示(涉及表情符号和口音)。我试图调和这些数据,以便将这两组数据正确地返回到我的iOS应用程序中。请帮帮我!

EN

回答 3

Stack Overflow用户

发布于 2014-12-09 22:23:59

为了Emoji和U+FFFF代码点以外的其他字符,我一直在努力在Python和U+FFFF之间正确地交换UTF-8字符。

为了确保一切顺利,我必须做以下工作:

  1. 确保utf8mb4用于CHARVARCHAR和MySQL中的TEXT
  2. 在Python中强制执行UTF-8
  3. 强制在Python和MySQL之间使用UTF-8

要在Python中强制执行UTF-8,请添加以下行作为Python脚本的第一行或第二行:

代码语言:javascript
复制
# -*- coding: utf-8 -*-

要在Python之间强制执行UTF-8,请按以下方式设置MySQL连接:

代码语言:javascript
复制
# 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()

这样,您就不需要使用像encodeutf8_encode这样的函数。

票数 26
EN

Stack Overflow用户

发布于 2016-12-18 04:23:04

use_unicode=True不是为我工作的。

我的解决方案

  • 在mysql中,将整个数据库、表和字段编码更改为utf8mb4。
  • MySQLdb.connect(host='###' [...], charset='utf8'
  • dbCursor.execute('SET NAMES utf8mb4')
  • dbCursor.execute("SET CHARACTER SET utf8mb4")
票数 2
EN

Stack Overflow用户

发布于 2019-09-23 11:35:31

还可以按以下方式输入所需代码的类型

代码语言:javascript
复制
mysql.connector.connect(host = '<host>', database = '<db>', user = '<user>', password = '<password>', charset = 'utf8')

“<>”中的字段是您自己的详细信息。与“utf8”不同,您还可以根据mysqldb需要的编码类型编写“utf8mb4”。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26532722

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档