圆月山庄资源网 Design By www.vgjia.com
本文实例为大家分享了python使用tornado实现简单爬虫的具体代码,供大家参考,具体内容如下
代码在官方文档的示例代码中有,但是作为一个tornado新手来说阅读起来还是有点困难的,于是我在代码中添加了注释,方便理解,代码如下:
# coding=utf-8 #!/usr/bin/env python import time from datetime import timedelta try: from HTMLParser import HTMLParser from urlparse import urljoin, urldefrag except ImportError: from html.parser import HTMLParser from urllib.parse import urljoin, urldefrag from tornado import httpclient, gen, ioloop, queues # 设置要爬取的网址 base_url = 'http://www.baidu.com' # 设置worker数量 concurrency = 10 # 此代码会获取base_url下的所有其他url @gen.coroutine def get_links_from_url(url): try: # 通过异步向url发起请求 response = yield httpclient.AsyncHTTPClient().fetch(url) print('fetched %s' % url) # 响应如果是字节类型 进行解码 html = response.body if isinstance(response.body, str) else response.body.decode(errors='ignore') # 构建url列表 urls = [urljoin(url, remove_fragment(new_url)) for new_url in get_links(html)] except Exception as e: print('Exception: %s %s' % (e, url)) # 报错返回空列表 raise gen.Return([]) # 返回url列表 raise gen.Return(urls) def remove_fragment(url): #去除锚点 pure_url, frag = urldefrag(url) return pure_url def get_links(html): #从html页面里提取url class URLSeeker(HTMLParser): def __init__(self): HTMLParser.__init__(self) self.urls = [] def handle_starttag(self, tag, attrs): href = dict(attrs).get('href') if href and tag == 'a': self.urls.append(href) url_seeker = URLSeeker() url_seeker.feed(html) return url_seeker.urls @gen.coroutine def main(): # 创建队列 q = queues.Queue() # 记录开始时间戳 start = time.time() # 构建两个集合 fetching, fetched = set(), set() @gen.coroutine def fetch_url(): # 从队列中取出数据 current_url = yield q.get() try: # 如果取出的数据在队列中已经存在 返回 if current_url in fetching: return print('fetching %s' % current_url) # 如果不存在添加到集合当中 fetching.add(current_url) # 从新放入的链接中继续获取链接 urls = yield get_links_from_url(current_url) # 将已经请求玩的url放入第二个集合 fetched.add(current_url) for new_url in urls: # Only follow links beneath the base URL # 如果链接是以传入的url开始则放入队列 if new_url.startswith(base_url): yield q.put(new_url) finally: # 队列内数据减一 q.task_done() @gen.coroutine def worker(): while True: # 保证程序持续运行 yield fetch_url() # 将第一个url放入队列 q.put(base_url) # Start workers, then wait for the work queue to be empty. for _ in range(concurrency): # 启动对应数量的worker worker() # 等待队列数据处理完成 yield q.join(timeout=timedelta(seconds=300)) # 如果两个集合不相等抛出异常 assert fetching == fetched # 打印执行时间 print('Done in %d seconds, fetched %s URLs.' % ( time.time() - start, len(fetched))) if __name__ == '__main__': io_loop = ioloop.IOLoop.current() io_loop.run_sync(main)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月07日
2024年11月07日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]