[Python] UnicodeDecodeError: 'ascii' codec can't decode byte 0xe3

Tue, June 19, 2012 - 2 min read

Python + Google App Engine の勉強を下記サイトに沿ってしていたところ、文字コードでつまずいて解決したお話です。

Python

【libro】 PythonによるGoogle App Engine(GAE)プログラミング入門

#!/usr/bin/env python
#-*- coding: utf-8 -*-
#
import os
from google.appengine.ext import webapp, db
from google.appengine.ext.webapp import util, template

class MainHandler(webapp.RequestHandler):
  def get(self):
    params = {'message':'これは、テンプレートで出力したWebページです。'}
    fpath = os.path.join(os.path.dirname(__file__),'views','index.html')
    html = template.render(fpath, params)
    self.response.headers['Content-Type'] = 'text/html'
    self.response.out.write(html)
  
  def post(self):
    text1 = self.request.get('text1')
    params = {'message':'こんにちは、' + text1 + 'さん!'}
    fpath = os.path.join(os.path.dirname(__file__),'views','index.html')
    html = template.render(fpath, params)
    self.response.headers['Content-Type'] = 'text/html'
    self.response.out.write(html)

def main():
  application = webapp.WSGIApplication([('/', MainHandler)],
                                         debug=True)
  util.run_wsgi_app(application)

if __name__ == '__main__':
  main()

post で渡された日本語文字を表示させようとしたら下記のようなエラーが表示されました。

Traceback (most recent call last): File "/Applications/GoogleAppEngineLauncher.app/Contents/Resources/GoogleAppEngine-default.bundle/Contents/Resources/google_appengine/google/appengine/ext/webapp/__init__.py", line 636, in __call__ handler.post(*groups) File "/Users/your_username/gae/sandbox/main.py", line 20, in post params = {'message':'こんにちは、' + text1 + 'さん!'} UnicodeDecodeError: 'ascii' codec can't decode byte 0xe3 in position 0: ordinal not in range(128)

文字コードでつまずいたらここを読んで復習するようにしています。

・参考:PythonのUnicodeEncodeErrorを知る - HDEラボ

17行目を以下のように修正すればエラーが消えました。

    text1 = self.request.get('text1').encode('utf-8')

以上です。