我正在将ebay sdk移植到python3,我偶然发现了以下问题。
我正在使用pycurl发送一些HTTP请求。下面是我如何配置它:
self._curl = pycurl.Curl()
self._curl.setopt(pycurl.FOLLOWLOCATION, 1)
self._curl.setopt(pycurl.URL, str(request_url))
self._curl.setopt(pycurl.SSL_VERIFYPEER, 0)
self._response_header = io.StringIO()
self._response_body = io.StringIO()
self._curl.setopt(pycurl.CONNECTTIMEOUT, self.timeout)
self._curl.setopt(pycurl.TIMEOUT, self.timeout)
self._curl.setopt(pycurl.HEADERFUNCTION, self._response_header.write)
self._curl.setopt(pycurl.WRITEFUNCTION, self._response_body.write)当我调用self._curl.perform()时,我得到以下错误:
pycurl.error: (23, 'Failed writing body (1457 != 1460)')据我所知,这意味着写函数有问题,但我不知道它到底是什么。可能与从StringIO模块迁移到io有关,但我不确定。
UPD:我尝试了以下几种方法:
def body(buf):
self._response_body.write(buf)
def header(buf):
self._response_header.write(buf)
self._curl.setopt(pycurl.HEADERFUNCTION, header)
self._curl.setopt(pycurl.WRITEFUNCTION, body)而且起作用了。我试着用lambdas做同样的技巧(而不是定义那些尴尬的函数,但它没有起作用。
发布于 2014-05-12 13:23:30
我认为问题在于,吡咯烷酮不再像预期的那样与StringIO起作用。一个解决方案是使用io.BytesIO代替。然后,您可以将信息写入缓冲区并将其解码为字符串。
将BytesIO与pycurl一起使用而不是使用StringIO:
e = io.BytesIO()
c.setopt(pycurl.WRITEFUNCTION, e.write)从BytesIO对象解码字节信息:
htmlString = e.getvalue().decode('UTF-8')您可以使用任何类型的解码,但这应该会给您一个字符串对象,您可以解析。
希望这对使用Python 3的人有所帮助。
https://stackoverflow.com/questions/19606447
复制相似问题