17
# -*- coding: utf-8 -*- 
# Python3
import urllib
import urllib.request as url_req
opener = url_req.build_opener()
url='http://zh.wikipedia.org/wiki/'+"毛泽东"
opener.open(url).read()
# opener.open(url.encode("utf-8")).read()
# # doesn't work either

実行すると、次のように不平を言います。

UnicodeEncodeError: 'ascii' codec can't encode characters in position 10-12: ordinal not in range(128)

しかし、.encode()文句を言うのでどちらも使用できません:

Traceback (most recent call last):
  File "t.py", line 8, in <module>
    opener.open(url.encode("utf-8")).read()
  File "/usr/local/Cellar/python3/3.2.2/lib/python3.2/urllib/request.py", line 360, in open
    req.timeout = timeout
AttributeError: 'bytes' object has no attribute 'timeout'

誰もがそれに対処する方法を知っていますか?

4

3 に答える 3

24

urllib.parse.quote()を使用して、URL のパス セクションをエンコードできます。

#!/usr/bin/env python3
from urllib.parse   import quote
from urllib.request import urlopen

url = 'http://zh.wikipedia.org/wiki/' + quote("毛泽东")
content = urlopen(url).read()
于 2012-08-05T17:26:50.667 に答える
11

素晴らしいrequestsライブラリは、すぐにこれを行います。

>>> url='http://zh.wikipedia.org/wiki/'+"毛泽东"
>>> import requests
>>> r = requests.get(url)
>>> len(r.content)
818747
于 2012-08-05T17:21:00.183 に答える
2

URL の一部として任意の Unicode 文字列を使用することはできません。URL は適切にエンコードする必要があります。詳細はこちらをご覧ください:

http://www.w3schools.com/tags/ref_urlencode.asp

特に、URL を適切に引用するために、Python API の urllib.quote() または urllib.quote_plus() メソッドを使用する必要があります。

http://docs.python.org/library/urllib.html

于 2012-08-05T17:11:48.230 に答える