###1. 安装
pip install requests或者easy_install requestshtml
###2. 基本使用
在ipython中利用自动补全看下调用requests以后返回的response对象的一些属性:python
In [1]: import requests In [2]: r = requests.get('https://api.github.com') In [3]: r. r.apparent_encoding r.history r.raw r.close r.is_redirect r.reason r.connection r.iter_content r.request r.content r.iter_lines r.status_code r.cookies r.json r.text r.elapsed r.links r.url r.encoding r.ok r.headers r.raise_for_status
快速入门:http://requests-docs-cn.readthedocs.io/zh_CN/latest/user/quickstart.html git
高级的用法:http://requests-docs-cn.readthedocs.io/zh_CN/latest/user/advanced.htmlgithub
安装方法(不少同窗在安装过程当中遇到了问题),见个人上一篇博客。json
使用requests库获取到网页内容后,再经过lxml解析,也可经过BeautifulSoup等等工具api
lxml是基于C语言库libxml2和libxslt的python化绑定,其对XML(HTMl)有强大的处理能力,而且向下兼容Python的ElementTree API,支持Xpath和BeautifulSoup解析, 使用起来很是方便。cookie
官方教程:http://lxml.de/app
下面是一个在Windows平台下用python3.5用lxml解析HTML的例子,lxml经过xpath表达式来获取数据工具
(详见:http://www.cnblogs.com/descusr/archive/2012/06/20/2557075.html):ui
from lxml import etree html = ''' <html> <head> <meta name="content-type" content="text/html; charset=utf-8" /> <title>友情连接查询 - 站长工具</title> <!-- uRj0Ak8VLEPhjWhg3m9z4EjXJwc --> <meta name="Keywords" content="友情连接查询" /> <meta name="Description" content="友情连接查询" /> </head> <body> <h1 class="heading">Top News</h1> <p style="font-size: 200%">World News only on this page</p> Ah, and here's some more text, by the way. <p>... and this is a parsed fragment ...</p> <a href="http://www.cydf.org.cn/" rel="nofollow" target="_blank">青少年发展基金会</a> <a href="http://www.4399.com/flash/32979.htm" target="_blank">洛克王国</a> <a href="http://www.4399.com/flash/35538.htm" target="_blank">奥拉星</a> <a href="http://game.3533.com/game/" target="_blank">手机游戏</a> <a href="http://game.3533.com/tupian/" target="_blank">手机壁纸</a> <a href="http://www.4399.com/" target="_blank">4399小游戏</a> <a href="http://www.91wan.com/" target="_blank">91wan游戏</a> </body> </html> ''' page = etree.HTML(html.lower()) hrefs = page.xpath(u"//a") for href in hrefs: # print(href.attrib) print(href.text)