File "/usr/local/lib/python3.0/cgi.py", line 477, in __init__
self.read_urlencoded()
File "/usr/local/lib/python3.0/cgi.py", line 577, in read_urlencoded
self.strict_parsing):
File "/usr/local/lib/python3.0/urllib/parse.py", line 377, in parse_qsl
pairs = [s2 for s1 in qs.split('&') for s2 in s1.split(';')]
TypeError: Type str doesn't support the buffer API
任何人都可以指导我如何避免这种情况吗?我通过将数据输入cgi.Fieldstorage
得到它,我似乎无法以任何其他方式做到这一点。
答案 0 :(得分:28)
urllib正在尝试:
b'a,b'.split(',')
哪个不起作用。字节字符串和unicode字符串在Py3k中的混合程度甚至比以前更低 - 故意使编码问题尽快出错。
所以错误是不透明地告诉你'你不能将字节串传递给urllib.parse'。大概你正在做一个POST请求,其中表单编码的字符串作为内容体进入cgi;内容正文仍然是一个字节字符串/流,因此它现在与新的urllib冲突。
所以是的,这是cgi.py中的一个错误,但是2to3转换的另一个受害者还没有为新的字符串模型正确修复。它应该将传入的字节流转换为字符,然后再将它们传递给urllib。
我是否提到过Python 3.0的库(特别是与Web相关的库)仍然相当笨拙? : - )
答案 1 :(得分:13)
从python教程(http://www.python.org/doc/3.0/tutorial/stdlib.html)中有一个使用urlopen方法的例子。它引发了同样的错误。
for line in urlopen('http://tycho.usno.navy.mil/cgi-bin/timer.pl'):
if 'EST' in line or 'EDT' in line: # look for Eastern Time
print(line)
您需要使用str函数将byte thingo转换为具有正确编码的字符串。如下:
for line in urlopen('http://tycho.usno.navy.mil/cgi-bin/timer.pl'):
lineStr = str( line, encoding='utf8' )
if 'EST' in lineStr or 'EDT' in lineStr: # look for Eastern Time
print(lineStr)