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.
唯一永远不改变,是不停地改变~