Han*_*Sun 15 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
Run Code Online (Sandbox Code Playgroud)
当我运行它时,它抱怨:
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'
Run Code Online (Sandbox Code Playgroud)
谁知道如何处理?
jfs*_*jfs 21
您可以使用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()
Run Code Online (Sandbox Code Playgroud)
jte*_*ace 11
神奇的请求库为您提供了开箱即用的功能:
>>> url='http://zh.wikipedia.org/wiki/'+"???"
>>> import requests
>>> r = requests.get(url)
>>> len(r.content)
818747
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
12904 次 |
| 最近记录: |