Maison  >  Questions et réponses  >  le corps du texte

python - sqlalchemy更新数据报错

这是我的更新代码

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)   //这里报错
伊谢尔伦伊谢尔伦2741 Il y a quelques jours629

répondre à tous(1)je répondrai

  • PHPz

    PHPz2017-04-18 10:32:25

    Je n’ai pas beaucoup écrit à ce sujet, mais je suppose

    1. Assurez-vous que votre clé et votre valeur sont toutes deux Aucune
    2. N'avez-vous pas besoin de vous engager pour les mises à jour ?

      Il y a évidemment un problème avec le paramètre du jeu de caractères de la base de données. Veuillez définir le jeu de caractères de la base de données sur UTF-8
    1. .

    2. Si vous ne souhaitez pas mettre en place de base de données, décodez les données à insérer info_str.encode('votre format') et insérez-la
    3. répondre
      0
  • Annulerrépondre