这是我的更新代码
def alter(self,id,key,value):
session = Goods().getsession()
session.query(Goods).filter(Goods.id==id).update({key:value})
session.close()
但是会报错
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
最新查错。
打印如下
print type(id),type(key),type(value)
<type 'unicode'> <type 'unicode'> <type 'unicode'>
127.0.0.1 - - [31/Mar/2017 06:32:05] "GET /alter?id=1497&key=name&value=%E8%8D%A3%E8%80%80V9+%E6%89%8B%E6%9C%BA+%E9%93%82%E5%85%89%E9%87%91+%E5%85%A8%E7%BD%91%E9%80%9A4G(4G+RAM%2B64G+ROM)%E6%A0%87%E9%85%8D HTTP/1.1" 200 -
初步发现问题所在 数据库为latin1编码
然后封装json的时候
UnicodeDecodeError: 'utf8' codec can't decode bytes in position 90-91: unexpected end of data
代码
def get(self):
session = Goods().getsession()
goodslist = session.query(Goods)
session.close()
data = []
for goods in goodslist:
tmp = {}
tmp['id'] = goods.id
tmp['name'] = goods.name //这里报错根源 带空格
tmp['link'] = goods.link
tmp['price'] = goods.price
tmp['commit'] = goods.commit
data.append(tmp)
jsondata = json.dumps(data) //这里报错
많이 쓰지는 않았지만 추측해봅니다
1. 키와 값이 None인지 확인2. 업데이트 시 커밋할 필요가 없습니다분명히 데이터베이스 문자 집합 설정에 문제가 있습니다. 데이터베이스 문자 집합을 UTF-8로 설정하세요
데이터베이스 설정을 원하지 않는 경우에는 삽입할 데이터를 디코딩하여 info_str.encode('사용자 형식')을 입력한 후