2011-12-08 68 views
2

我想从Twitter获取推文,并通过GTalk使用GAE中的xmpp API发送它。我有一个很奇怪的问题。奇怪的GAE Python编码问题

我有成功检索到来自Twitter的数据。使用XMPP API发送错误时发生错误。根据跟踪信息,错误发生在GAE代码中,而不是我自己的。我已经用Python2.5测试了特定的推文,并且它能够正确处理推文文本,并且推文仅包含英文字符。

ERROR 2011-12-08 14:29:54,200 dev_appserver.py:2700] Exception encountered handling request 
Traceback (most recent call last): 
    File "/home/google_appengine/google/appengine/tools/dev_appserver.py", line 2641, in _HandleRequest 
    self._Dispatch(dispatcher, self.rfile, outfile, env_dict) 
    File "/home/google_appengine/google/appengine/tools/dev_appserver.py", line 2528, in _Dispatch 
    base_env_dict=env_dict) 
    File "/home/google_appengine/google/appengine/tools/dev_appserver.py", line 616, in Dispatch 
    base_env_dict=base_env_dict) 
    File "/home/google_appengine/google/appengine/tools/dev_appserver.py", line 1592, in Dispatch 
    self._module_dict) 
    File "/home/google_appengine/google/appengine/tools/dev_appserver.py", line 1517, in ExecuteCGI 
    logservice_stub._flush_logs_buffer() 
    File "/home/google_appengine/google/appengine/api/logservice/logservice_stub.py", line 71, in _flush_logs_buffer 
    logservice.logs_buffer().flush() 
    File "/home/google_appengine/google/appengine/api/logservice/logservice.py", line 228, in flush 
    self._lock_and_call(self._flush) 
    File "/home/google_appengine/google/appengine/api/logservice/logservice.py", line 112, in _lock_and_call 
    return method(*args) 
    File "/home/google_appengine/google/appengine/api/logservice/logservice.py", line 260, in _flush 
    apiproxy_stub_map.MakeSyncCall('logservice', 'Flush', request, response) 
    File "/home/google_appengine/google/appengine/api/apiproxy_stub_map.py", line 94, in MakeSyncCall 
    return stubmap.MakeSyncCall(service, call, request, response) 
    File "/home/google_appengine/google/appengine/api/apiproxy_stub_map.py", line 308, in MakeSyncCall 
    rpc.CheckSuccess() 
    File "/home/google_appengine/google/appengine/api/apiproxy_rpc.py", line 156, in _WaitImpl 
    self.request, self.response) 
    File "/home/google_appengine/google/appengine/api/apiproxy_stub.py", line 87, in MakeSyncCall 
    method(request, response) 
    File "/home/google_appengine/google/appengine/api/logservice/logservice_stub.py", line 309, in _Dynamic_Flush 
    new_app_logs = self.put_log_lines(group.log_line_list()) 
    File "/home/google_appengine/google/appengine/api/logservice/logservice_stub.py", line 321, in put_log_lines 
    return _run_in_namespace(self._put_log_lines, lines) 
    File "/home/google_appengine/google/appengine/api/logservice/logservice_stub.py", line 93, in _run_in_namespace 
    return f(*args) 
    File "/home/google_appengine/google/appengine/api/logservice/logservice_stub.py", line 330, in _put_log_lines 
    message=app_log.message()) 
    File "/home/google_appengine/google/appengine/ext/db/__init__.py", line 945, in __init__ 
    prop.__set__(self, value) 
    File "/home/google_appengine/google/appengine/ext/db/__init__.py", line 599, in __set__ 
    value = self.validate(value) 
    File "/home/google_appengine/google/appengine/ext/db/__init__.py", line 2696, in validate 
    value = self.data_type(value) 
    File "/home/google_appengine/google/appengine/api/datastore_types.py", line 1138, in __new__ 
    return super(Text, cls).__new__(cls, arg, encoding) 
UnicodeDecodeError: 'ascii' codec can't decode byte 0xca in position 135: ordinal not in range(128) 
+0

''ascii'编解码器无法解码字节0xca' – Kjuly

+0

有点偏离主题:有问题与twitter和GAE afaik。 Twitter会按域进行限制 - 如果您使用的是appspot,则与其他正在与appspot上的twitter进行交谈的应用程序共享有限的资源 - 我们发现很难处理这些资源。不知道它是否仍然如此。 –

+0

它们通过IP进行节制,而不是域,虽然效果是相同的:App引擎请求池在一起,并被视为一个非常繁忙的应用程序。如果这是问题,你可能会得到一个DownloadError而不是UnicodeDecodeError。 –

回答

1

对不起球员...虚惊:(

这一问题的原因是谷歌日志服务只接受“ASCII”编解码器,当我在本地测试XMPP服务,它使用日志服务以显示消息,并且我发送的消息是Unicode,因此发生错误。

解决方案是在测试时使用str.encode('ascii','ignore'),或者干脆忽略该错误。

1

此错误表示您尝试将多字节字符存储在7位ASCII字符串中。通过HTTP响应身体作为unicode来避免这种情况。如果您需要更具体的建议,请发布您的代码。

+0

这不是“7位ASCII字符串”或“多字节字符”。这意味着他们试图使用ASCII解码字符串,但该字符串包含ASCII范围之外的代码点。 –