如何在python3中处理URL中的unicode字符串?

时间:2012-08-05 17:05:32

标签: python unicode python-3.x

# -*- 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'

有谁知道如何处理?

3 个答案:

答案 0 :(得分:21)

您可以使用urllib.parse.quote()对网址的路径部分进行编码。

#!/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()

答案 1 :(得分:11)

梦幻般的requests库为您提供了开箱即用的功能:

>>> url='http://zh.wikipedia.org/wiki/'+"毛泽东"
>>> import requests
>>> r = requests.get(url)
>>> len(r.content)
818747

答案 2 :(得分:2)

您不能将任意unicode字符串用作URL的一部分。 URL必须正确 编码。有关详细信息,请参见此处:

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

特别要使用urllib.quote()或urllib.quote_plus()方法 用于正确引用您的URL的Python API。

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