asyncio+aiohttp实现的爬虫如何查看返回的数据

本文介绍了在使用Python的asyncio和aiohttp库编写爬虫时,如何查看和处理爬虫的返回数据。通过协程的高并发特性提升爬虫效率,并展示了在单个及多个协程情况下,如何获取并打印返回的dict数据。

是这样的,有时候,大多时候,写爬虫程序的时候需要返回值的.

大家知道,协程的高并发性能是能够提高爬虫的效率的,好让程序有其他的时间去执行其他的代码.

但是我最近在猜测,如何查看爬虫的返回值呢?

详细代码就不写了,后面上贴图吧...
loop = asyncio.get_event_loop()
task = asyncio.ensure_future(self.Request())
result = loop.run_until_complete(task) 

result 返回值直接就是你的返回值!

这个是单个协程的情况.

我们来讲讲多个协程...

loop = asyncio.get_event_loop()
task = [self.Request() for i in range(3)]
result = loop.run_until_complete(asyncio.wait(task)) # result返回为元组,第一个是数据包,包含很多的数据(我们想要的数据段就在这个位置), 第二个是一个空的set()
for i in result[0]:
    print(i.result()) 
通过debug我们可以看到一个_result的dict()

因为我的返回值就是一个dict,所以我们可以用for迭代来取出里面的数据

for data in result[0]:#注意是第一个!

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值