今天用到是python自带的库: threading
在之前发布的 《python-多线程-初识》中,当时使用的是一个for in的语句,在语句的内部创建线程,而没有添加限制条件。那么这样就可能会有一个问题,当任务数较大时,线程并发数也会达到较大的一个数值,那么就会给个人电脑或者对端服务器带来不小的负担,还有可能会触发对端服务器的某些自我保护方式,那么有什么方法可以有效的规避这种情况呢,它今天来了。
使用工具:threading,requests
环境准备:
搭建python开发环境
若前期未安装requests库的话,需要安装一下
pip install requests
源码讲解环节
好的,下面就是喜闻乐见的源码讲解环节了(´◔౪◔)
import threading
import requests
# 文件下载模块
def down_loads(i,url):
header = {"User-Agent":"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; AcooBrowser; .NET CLR 1.1.4322; .NET CLR 2.0.50727)"}
r = requests.get(url, headers=header).content
with open(r'123\{}.jpg'.format(i), 'wb')as f:
f.write(r)
<