在 windows 系统下,只需要输入命令 pip install requests ,即可安装。
在 linux 系统下,只需要输入命令 sudo pip install requests ,即可安装。
或者
=================
Window
1. 下载requests 被墙
打开这个网址, http://www.lfd.uci.edu/~gohlke/pythonlibs 在这个网站上面有很多 python 的第三方库文件, ctrl+f 找到 requests 下载
.whl文件下载下来后,将后缀名从 .whl 改为 .zip ,然后解压文件,我们可以得到两个文件夹
将requests 文件夹复制到 python 的安装目录下的 lib 目录下
requests 已经安装完毕,输入 import requests 命令来试试是否安装成功,
import requests 没有报错,说明 requests 已经成功安装。
2.快速指南
2.1 发送请求
发送请求很简单的,首先要导入requests模块:
>>>import requests
接下来让我们获取一个网页,例如我个人博客的首页:
>>>r = requests.get('http://www.zhidaow.com')
接下来,我们就可以使用这个r的各种方法和函数了。
另外,HTTP请求还有很多类型,比如POST,PUT,DELETE,HEAD,OPTIONS。也都可以用同样的方式实现:
>>> r = requests.post("http://httpbin.org/post")>>> r = requests.put("http://httpbin.org/put")>>> r = requests.delete("http://httpbin.org/delete")>>> r = requests.head("http://httpbin.org/get")>>> r = requests.options("http://httpbin.org/get")
因为目前我还没用到这些,所以没有深入研究。
2.2 在URLs中传递参数
有时候我们需要在URL中传递参数,比如在采集百度搜索结果时,我们wd参数(搜索词)和rn参数(搜素结果数量),你可以手工组成URL,requests也提供了一种看起来很NB的方法:
>>> payload = {'wd': '张亚楠', 'rn': '100'}>>> r = requests.get("http://www.baidu.com/s", params=payload)>>> print r.urlu'http://www.baidu.com/s?rn=100&wd=%E5%BC%A0%E4%BA%9A%E6%A5%A0'
上面wd=的乱码就是“张亚楠”的转码形式。(好像参数按照首字母进行了排序。)
2.3 获取响应内容
可以通过r.text来获取网页的内容。
>>> r = requests.get('https://www.zhidaow.com')>>> r.textu'<!DOCTYPE html>/n<html xmlns="http://www.w3.org/1999/xhtml"...'
文档里说,requests会自动将内容转码。大多数unicode字体都会无缝转码。但我在cygwin下使用时老是出现UnicodeEncodeError错误,郁闷。倒是在python的IDLE中完全正常。
另外,还可以通过r.content来获取页面内容。
>>> r = requests.get('https://www.zhidaow.com')>>> r.contentb'<!DOCTYPE html>/n<html xmlns="http://www.w3.org/1999/xhtml"...'
新闻热点
疑难解答