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.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值