23
  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いますが、他の方法ではできないようです。

4

2 に答える 2

28

urllibは次のことを行おうとしています。

b'a,b'.split(',')

これは機能しません。バイト文字列とUnicode文字列は、Py3kで以前よりもスムーズに混合されません。意図的に、エンコードの問題を後でではなく早く失敗させるためです。

したがって、エラーは「バイト文字列をurllib.parseに渡すことができない」ことをかなり不透明に示しています。おそらく、POSTリクエストを実行しており、フォームでエンコードされた文字列がコンテンツ本文としてcgiに送られます。コンテンツ本体はまだバイト文字列/ストリームであるため、新しいurllibと衝突するようになりました。

そうですね、これはcgi.pyのバグですが、2to3変換のもう1つの犠牲者であり、新しい文字列モデルでは適切に修正されていません。着信バイトストリームをurllibに渡す前に、文字に変換する必要があります。

Python 3.0のライブラリ(特にWeb関連のライブラリ)はまだかなり派手だと言いましたか?:-)

于 2009-02-12T16:14:50.133 に答える
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関数を使用して、バイトを正しいエンコーディングの文字列に変換する必要があります。次のように:

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)
于 2010-01-29T01:13:39.583 に答える