decoding to str: need a bytes-like object, tuple found

一、

在访问python-web项目的某网页时,显示decoding to str: need a bytes-like object, tuple found错误。

二、

错误大概意思是解码成字符串是需要字节类的对象,但现在发现了一个元组类型对象。
找到后台代码:

db=pymysql.connect(host='localhost',port=3306,user='root',password='123456',database='stock_db',charset='utf8')
cursor=db.cursor()
sql="select * from info;"
cursor.execute(sql)
data_from_mysql=cursor.fetchall()
cursor.close()
db.close()
content=re.sub(r"\{%content%\}", data_from_mysql, content)
return content

发现

data_from_mysql=cursor.fetchall()

返回的是是多行记录,是一个二维元组。类似于((username1,password1,nickname1),(username2,password2,nickname2),(username3,password3,nickname))
而在

content=re.sub(r"\{%content%\}", data_from_mysql, content)

中直接将data_from_mysql当做字符串来处理~

解决:

content=re.sub(r"\{%content%\}", data_from_mysql, content)

改成

content=re.sub(r"\{%content%\}", str(data_from_mysql), content)

,也就是使用str来转化data_from_mysql的类型。



Accept what was and what is, and you’ll have more positive energy to pursue what will be.

posted @ 2020-07-16 08:41  晓风残月龙  阅读(688)  评论(0编辑  收藏  举报