前提・実現したいこと
pythonでドコモの雑談対話APIを使う、スクリプトを書いています。
以下の内容で実行したときに、2回目の入力で日本語を入力すると、以下のエラーが
出力されてしまいます…。
※半角英数字だとエラーになりません。
※1回目は正常に日本語で会話ができます。
発生している問題・エラーメッセージ
Traceback (most recent call last): File "test8_27.py", line 36, in <module> r = requests.post(url, data=json.dumps(payload), headers=headers) File "C:\Python27\lib\json\__init__.py", line 244, in dumps return _default_encoder.encode(obj) File "C:\Python27\lib\json\encoder.py", line 207, in encode chunks = self.iterencode(o, _one_shot=True) File "C:\Python27\lib\json\encoder.py", line 270, in iterencode return _iterencode(o, 0) UnicodeDecodeError: 'utf8' codec can't decode byte 0x82 in position 0: invalid s tart byte
該当のソースコード
python2.7.14
1# -*- coding: utf-8 -*- 2 3import requests 4import json 5import types 6 7KEY = 'XXXXXXX' 8#APIキーが入ります 9 10 11endpoint = 'https://api.apigw.smt.docomo.ne.jp/dialogue/v1/dialogue?APIKEY=REGISTER_KEY' 12url = endpoint.replace('REGISTER_KEY', KEY) 13 14utt_content = raw_input('>>') 15 16payload = {'utt' : 'utt_content', 'context': ''} 17headers = {'Content-type': 'application/json'} 18 19r = requests.post(url, data=json.dumps(payload), headers=headers) 20data = r.json() 21 22response = data['utt'] 23context = data['context'] 24print "response: %s, context: %s" %(response, context) 25 26 27#2回目以降の会話(Ctrl+Cで終了) 28 29while True: 30 utt_content = raw_input('>>') 31 32 payload['utt'] = utt_content 33 payload['context'] = data['context'] 34 35 36 r = requests.post(url, data=json.dumps(payload), headers=headers) 37 data = r.json() 38 39 response = data['utt'] 40 context = data['context'] 41 42 print "response: %s, context: %s" %(response, context)
試したこと
・1回目の会話→成功
・2回目の会話を半角英字の文字を入力→成功
・2回目の会話を日本語の文字を入力→失敗
補足情報(FW/ツールのバージョンなど)
・python2.7.14
・実効環境 windowsのコマンドプロンプト