我正在尝试编写一个使用 urllib2 并进行一些错误处理的简单程序。代码如下所示
try:
urllib2.Request(...)
except HTTPError as e:
self.log.debug("HTTP Error for url %s is %s" % (e.url, e.read()))
关键是除了 e.message 之外,只需完整地转储错误页面。但是有时我会收到UnicodeDecodeError: 'ascii' codec can't decode byte 0xc2 in position 4030: ordinal not in range(128)
我认为是因为 e.read() 假设内容为 ascii char 集的消息,因为返回的页面可能还有其他内容。
我的问题是我该如何解决这个问题?即,我想转储一个“合理”的信息性消息。我同意这也取决于我尝试连接的 URL 返回的字符集和编码,但如果我的 Python e.read 方法中有任何方法不尝试确保 ASCII 字符